(3) 创建多声明表值型用户自定义函数 其语法如下:
各参数说明如下: - @return_variable
一个TABLE 类型的变量,用于存储和累积返回的表中的数据行。 - 其余参数与标量型用户自定义函数相同。
在多声明表值型用户自定义函数的函数体中允许使用下列Transact-SQL 语句。 - 赋值语句(Assignment statements);
- 流程控制语句(Control-of-Flow statements);
- 定义作用范围在函数内的变量和游标的DECLARE 语句;
- SELECT 语句;
- 编辑函数中定义的表变量的INSERT、 UPDATE 和DELETE 语句;
- 在函数中允许涉及诸如声明游标、打开游标、关闭游标、释放游标这样的游标操作,对于读取游标而言,除非在FETCH 语句中使用INTO 从句来对某一变量赋值,否则不允许在函数中使用FETCH 语句来向客户端返回数据。
???????????????? 此外不确定性函数(Non-deterministic functions) 不能在用户自定义函数中使用。所谓不确定性函数是指那些使用相同的调用参数在不同时刻调用得到的返回值不同的函数。这些函数如表13-3 所示(全局变量也可以视为一种函数)。
(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 新增的“用户自定义函数”的创建和使用。 
2/2 首页 上一页 1 2 |