13.13.1 创建用户自定义函数SQL Server 2000 为三种类型的用户自定义函数提供了不同的命令创建格式。(1) 创建标量型用户自定义函数(Scalar functions) 其语法如下:
各参数说明如下:
owner_name指定用户自定义函数的所有者。 function_name指定用户自定义函数的名称。database_name.owner_name.function_name 应是惟一的。 @parameter_name定义一个或多个参数的名称。一个函数最多可以定义1024 个参数每个参数前用“@”符号标明。参数的作用范围是整个函数。参数只能替代常量,不能替代表名、列名或其它数据库对象的名称。用户自定义函数不支持输出参数。 scalar_parameter_data_type指定标量型参数的数据类型,可以为除TEXT、 NTEXT、 IMAGE、 CURSOR、TIMESTAMP 和TABLE 类型外的其它数据类型。 scalar_return_data_type指定标量型返回值的数据类型,可以为除TEXT、 NTEXT、 IMAGE、 CURSOR、TIMESTAMP 和TABLE 类型外的其它数据类型。 scalar_expression指定标量型用户自定义函数返回的标量值表达式。 function_body指定一系列的Transact-SQL 语句,它们决定了函数的返回值。 ENCRYPTION加密选项。让SQL Server 对系统表中有关CREATE FUNCTION 的声明加密,以防止用户自定义函数作为SQL Server 复制的一部分被发布(Publish) 。 SCHEMABINDING计划绑定选项将用户自定义函数绑定到它所引用的数据库对象如果指定了此选项,则函数所涉及的数据库对象从此将不能被删除或修改,除非函数被删除或去掉此选项。应注意的是,要绑定的数据库对象必须与函数在同一数据库中。 (2) 创建内联表值型用户自定义函数(Inline Table-valued Functions)其语法如下: 各参数说明如下: TABLE 指定返回值为一个表。 select-stmt单个SELECT 语句,确定返回的表的数据。其余参数与标量型用户自定义函数相同。 (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: 删除用户自定义函数chiefinfodrop function chiefinfo 本章小结 本章主要介绍了SQL Server 中极为重要的两个概念:游标和视图,游标最为突出的贡献在于其实现了对结果的行操作,从而可以在应用程序中对同一结果集施加不同的数据操作,在面向集合的数据库管理系统和面向行的程序设计两者之间架起了“沟通”的桥梁,实现了两个数据处理方式的自由交流。视图作为一个查询结果集虽然仍与表具有相似的结构,但它是一张虚表,以视图结构显示在用户面前的数据并不是以视图的结构存储在数据库中,而是存储在视图所引用的基本表当中。视图的存在为保障数据库的安全性提供了新手段。除此之外,读者从本章中也可以了解到SQL Server 2000 新增的“用户自定义函数”的创建和使用。