除了使用系统提供的函数外,用户还可以根据需要自定义函数。用户自定义函数(user defined functions)是sql server 2000 新增的数据库对象,是sql server 的一大改进。 用户自定义函数不能用于执行一系列改变数据库状态的操作,但它可以像系统函数一样在查询或存储过程等的程序段中使用,也可以像存储过程一样通过execute 命令来执行。用户自定义函数中存储了一个transact-sql 例程,可以返回一定的值。 在sql server 2000 中根据函数返回值形式的不同将用户自定义函数分为三种类型:
(4) 用enterprise manager 创建用户自定义函数 用enterprise manager 创建用户自定义函数的方法是:在enterprise manager 中选择要创建用户自定义函数的数据库。在数据库对象“user defined functions” 上单击右键,从开始菜单中选择“new user defined function” 选项,就会出现如图13-4 所示的定义用户自定义函数属性对话框。可以在其中指定要定义的函数的名称,并编辑函数的脚本。单击“ok”按钮,则添加用户自定义函数对象到数据库中。
图13-4 定义用户自定义函数属性对话框
13.13.2 修改和删除用户自定义函数 在enterprise manager 中选择要进行改动的用户自定义函数,单击右键从快捷菜单中选择“属性”选项,则会出现与图13-4 类似的修改用户自定义函数结构对话框。可以修改用户自定义函数的函数体、参数等。从快捷菜单中选择“删除”选项,则可删除用户自定义函数。 用alter function 命令也可以修改用户自定义函数。此命令的语法与createfunction 相同,因此使用alter function 命令其实相当于重建了一个同名的函数,用起来不大方便。 另外,可以用drop function 命令删除用户自定义函数,其语法如下: drop function { [ owner_name. ] function_name } [ ,...n ] 例13-22: 删除用户自定义函数chiefinfo drop function chiefinfo
本章小结 本章主要介绍了sql server 中极为重要的两个概念:游标和视图,游标最为突出的贡献在于其实现了对结果的行操作,从而可以在应用程序中对同一结果集施加不同的数据操作,在面向集合的数据库管理系统和面向行的程序设计两者之间架起了“沟通”的桥梁,实现了两个数据处理方式的自由交流。视图作为一个查询结果集虽然仍与表具有相似的结构,但它是一张虚表,以视图结构显示在用户面前的数据并不是以视图的结构存储在数据库中,而是存储在视图所引用的基本表当中。视图的存在为保障数据库的安全性提供了新手段。除此之外,读者从本章中也可以了解到sql server 2000 新增的“用户自定义函数”的创建和使用。