- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第9章 SQL Server 2005高级开发
SQL Server 2005数据库管理与开发教程 第9章 SQL Server 2005高级开发 本章主要介绍SQL Server 2005的高级应用,包括用户自定义函数、实现交叉表查询、事务处理以及锁。 通过本章的学习,读者可以创建和管理用户自定义函数,可以使用PIVOT、UNPIVOT以及CASE实现交叉表查询,并了解事务处理机制和锁,应用事务和锁优化对数据的访问。 9.1 用户自定义函数 SQL Server 2005还可以根据用户需要来自定义函数,以便用在允许使用系统函数的任何地方。 用户自定义函数有两种方法,一种是利用Microsoft SQL Server Manager管理器直接创建,另一种是利用代码创建。 9.1.1 创建用户自定义函数 9.1.2 使用Transact-SQL语言创建用 户自定义函数 (1)创建自定义函数 利用Transact-SQL创建函数的语法如下: create function 函数名(@parameter 变量类型 [,@parameter 变量类型 ]) returns参数as begin 命令行或程序块 End 函数可以有0个或若干个输入参数,但必须有返回值,returns后面就是设置函数的返回值类型。 用户自定义函数为标量值函数或表值函数。 如果returns子句指定了一种标量数据类型,则函数为标量值函数;如果returns子句指定TABLE,则函数为表值函数。 根据函数主体的定义方式,表值函数可分为内联函数和多语句函数。 (1)标量函数 创建标量函数的语法如下: CREATE FUNCTION [ schema_name. ] function_name ( [ { @parameter_name [ AS ][ type_schema_name. ]?parameter_data_type [ = default ] } [ ,...n ]]) RETURNS return_data_type [ WITH function_option [ ,...n ] ] [ AS ] BEGIN function_body RETURN scalar_expression END 其中各参数的含义如下: ① schema_name 用户自定义函数所属的架构的名称。 ② function_name 用户自定义函数的名称。 ③ @parameter_name 用户自定义函数的参数 ④ [ type_schema_name. ] parameter_data_type 参数的数据类型及其所属的架构,前者为可选项。 ⑤ [ = default ] 参数的默认值。 ⑥ return_data_type 用户自定义标量函数的返回值。 ⑦ function_body 函数体,指定一系列定义函数值的Transact-SQL语句。 ⑧ scalar_expression 指定标量函数返回的标量值。 ⑨ function_option 指定函数将具有以下一个或多个选项。 Create function max1(@x int,@y int) Returns int as Begin If @x@y Set @x=@y Return @x end (2)内嵌表值函数 创建内嵌表值函数的语法如下 CREATE FUNCTION [ schema_name. ] function_name ( [ { @parameter_name?[ AS ] [ type_schema_name. ]?parameter_data_type [ = default ] } [ ,...n ]]) RETURNS TABLE [ WITH function_option [ ,...n ] ] [ AS ] RETURN ( select_stmt ) 其中各参数的含义如下: schema_name、function_name、@parameter_name、[ type_schema_name. ] parameter_data_type、[ = default ]、functi
文档评论(0)