欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年sql2k增加的Function的sqlbook的帮助SQL server]教程.docx

    • 资源ID:81146543       资源大小:15.63KB        全文页数:14页
    • 资源格式: DOCX        下载积分:9.9金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要9.9金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    2022年sql2k增加的Function的sqlbook的帮助SQL server]教程.docx

    2022年sql2k增加的Function的sqlbook的帮助SQL server教程CREATE FUNCTION创建用户定义函数,它是返回值的已保存的 Transact-SQL 例程。用户定义函数不能用于执行一组修改全局数据库状态的操作。与系统函数一样,用户定义函数可以从查询中唤醒调用。也可以像存储过程一样,通过 EXECUTE 语句执行。用户定义函数用 ALTER FUNCTION 修改,用 DROP FUNCTION 除去。语法标量函数CREATE FUNCTION owner_name. function_name( { parameter_name AS scalar_parameter_data_type = default } ,.n )RETURNS scalar_return_data_type WITH < function_option> , .n AS BEGINfunction_bodyRETURN scalar_expressionEND内嵌表值函数CREATE FUNCTION owner_name. function_name( { parameter_name AS scalar_parameter_data_type = default } ,.n )RETURNS TABLE WITH < function_option > , .n AS RETURN ( select-stmt ) 多语句表值函数CREATE FUNCTION owner_name. function_name( { parameter_name AS scalar_parameter_data_type = default } ,.n )RETURNS return_variable TABLE < table_type_definition > WITH < function_option > , .n AS BEGINfunction_bodyRETURNEND< function_option > :={ ENCRYPTION | SCHEMABINDING }< table_type_definition > :=( { column_definition | table_constraint } ,.n )参数owner_name拥有该用户定义函数的用户 ID 的名称。owner_name 必需是现有的用户 ID。function_name用户定义函数的名称。函数名称必需符合标识符的规则,对其全部者来说,该名称在数据库中必需是唯一的。parameter_name用户定义函数的参数。CREATE FUNCTION 语句中可以声明一个或多个参数。函数最多可以有 1,024 个参数。函数执行时每个已声明参数的值必需由用户指定,除非该参数的默认值已经定义。 假如函数的参数有默认值,在调用该函数时必需指定default关键字才能获得默认值。这种行为不同于存储过程中有默认值的参数,在存储过程中省略参数也意味着运用默认值。运用 符号作为第一个字符来指定参数名称。参数名称必需符合标识符的规则。每个函数的参数仅用于该函数本身;相同的参数名称可以用在其它函数中。参数只能代替常量;而不能用于代替表名、列名或其它数据库对象的名称。scalar_parameter_data_type参数的数据类型。全部标量数据类型(包括 bigint 和 sql_variant)都可用作用户定义函数的参数。不支持 timestamp 数据类型和用户定义数据类型。不能指定非标量类型(例如 cursor 和 table)。scalar_return_data_type是标量用户定义函数的返回值。scalar_return_data_type 可以是 SQL Server 支持的任何标量数据类型(text、ntext、image 和 timestamp 除外)。scalar_expression指定标量函数返回的标量值。TABLE指定表值函数的返回值为表。在内嵌表值函数中,通过单个 SELECT 语句定义 TABLE 返回值。内嵌函数没有相关联的返回变量。在多语句表值函数中,return_variable 是 TABLE 变量,用于存储和累积应作为函数值返回的行。function_body指定一系列 Transact-SQL 语句定义函数的值,这些语句合在一起不会产生副作用。function_body 只用于标量函数和多语句表值函数。在标量函数中,function_body 是一系列合起来求得标量值的 Transact-SQL 语句。在多语句表值函数中,function_body 是一系列填充表返回变量的 Transact-SQL 语句。select-stmt是定义内嵌表值函数返回值的单个 SELECT 语句。ENCRYPTION指出 SQL Server 加密包含 CREATE FUNCTION 语句文本的系统表列。运用 ENCRYPTION 可以避开将函数作为 SQL Server 复制的一部分发布。SCHEMABINDING指定将函数绑定到它所引用的数据库对象。假如函数是用 SCHEMABINDING 选项创建的,则不能更改(运用 ALTER 语句)或除去(运用 DROP 语句)该函数引用的数据库对象。函数与其所引用对象的绑定关系只有在发生以下两种状况之一时才被解除:除去了函数。在未指定 SCHEMABINDING 选项的状况下更改了函数(运用 ALTER 语句)。只有在满意以下条件时,函数才能绑定到架构:该函数所引用的用户定义函数和视图也已绑定到架构。该函数所引用的对象不是用两部分名称引用的。该函数及其引用的对象属于同一数据库。执行 CREATE FUNCTION 语句的用户对全部该函数所引用的数据库对象都具有 REFERENCES 权限。假如不符合以上条件,则指定了 SCHEMABINDING 选项的 CREATE FUNCTION 语句将失败。注释用户定义函数为标量值函数或表值函数。假如 RETURNS 子句指定一种标量数据类型,则函数为标量值函数。可以运用多条 Transact-SQL 语句定义标量值函数。假如 RETURNS 子句指定 TABLE,则函数为表值函数。依据函数主体的定义方式,表值函数可分为行内函数或多语句函数。假如 RETURNS 子句指定的 TABLE 不附带列的列表,则该函数为行内函数。行内函数是运用单个 SELECT 语句定义的表值函数,该语句组成了函数的主体。该函数返回的表的列(包括数据类型)来自定义该函数的 SELECT 语句的 SELECT 列表。假如 RETURNS 子句指定的 TABLE 类型带有列及其数据类型,则该函数是多语句表值函数。多语句函数的主体中允许运用以下语句。未在下面的列表中列出的语句不能用在函数主体中。赋值语句。限制流语句。DECLARE 语句,该语句定义函数局部的数据变量和游标。SELECT 语句,该语句包含带有表达式的选择列表,其中的表达式将值给予函数的局部变量。游标操作,该操作引用在函数中声明、打开、关闭和释放的局部游标。只允许运用以 INTO 子句向局部变量赋值的 FETCH 语句;不允许运用将数据返回到客户端的 FETCH 语句。INSERT、UPDATE 和 DELETE 语句,这些语句修改函数的局部 table 变量。EXECUTE 语句调用扩展存储过程。函数的确定性和副作用函数可以是确定的或不确定的。假如任何时候用一组特定的输入值调用函数时返回的结果总是相同的,则这些函数为确定的。假如每次调用函数时即运用的是相同的一组特定输入值,返回的结果总是不同的,则这些函数为不确定的。不确定的函数会产生副作用。副作用是更改数据库的某些全局状态,比如更新数据库表或某些外部资源,如文件或网络等(例如,修改文件或发送电子邮件消息)。不允许在用户定义函数主体中内置不确定函数;这些不确定函数如下:CONNECTIONS TOTAL_ERRORSCPU_BUSY TOTAL_READIDLE TOTAL_WRITEIO_BUSY GETDATEMAX_CONNECTIONS GETUTCDATEPACK_RECEIVED NEWIDPACK_SENT RANDPACKET_ERRORS TEXTPTRTIMETICKS尽管在用户定义函数主体中不允许有不确定函数,这些用户定义函数在调用扩展存储过程时仍会产生副作用。由于扩展存储过程会对数据库产生副作用,因此调用扩展存储过程的函数是不确定的。当用户定义函数调用会对数据库产生副作用的扩展存储过程时,不要希望结果集保持一样或执行函数。从函数中调用扩展存储过程从函数内部调用时扩展存储过程无法向客户端返回结果集。任何向客户端返回结果集的 ODS API 都将返回 FAIL。扩展存储过程可以连接回 Microsoft? SQL Server?;但是,它不应尝试联接与唤醒调用扩展存储过程的函数相同的事务。与从批处理或存储过程中唤醒调用相像,扩展存储过程在运行 SQL Server 的 Windows? 平安帐户的上下文中执行。存储过程的全部者在授予用户 EXECUTE 特权时应考虑这一点。函数调用在可运用标量表达式的位置可唤醒调用标量值函数,包括计算列和 CHECK 约束定义。当唤醒调用标量值函数时,至少应运用函数的两部分名称。database_name.owner_name.function_name (argument_expr,.)假如用户定义函数用于定义计算列,则该函数的确定性同样确定了是否可在该计算列上创建索引。只有当函数具有确定性时,才可以在运用该函数的计算列上创建索引。假如在输入相同的状况下函数始终返回相同的值,则该函数具有确定性。可以运用由一部分组成的名称唤醒调用表值函数。database_name.owner_name.function_name (argument_expr,.)对于 Microsoft? SQL Server? 2000 中包含的系统表函数,唤醒调用时需在函数名的前面加上前缀:。SELECT *FROM :fn_helpcollations()对于导致语句停止执行然后从存储过程中的下一语句接着执行的 Transact-SQL 错误,在函数中的处理方式不同。在函数中,这类错误会导致函数停止执行。这反过来使唤醒调用该函数的语句停止执行。权限用户应具有执行 CREATE FUNCTION 语句的 CREATE FUNCTION 权限。CREATE FUNCTION 的权限默认地授予 sysadmin 固定服务器角色和 db_owner 和 db_ddladmin 固定数据库角色的成员。sysadmin 和 db_owner 的成员可用 GRANT 语句将 CREATE FUNCTION 权限授予其它登录。函数的全部者对其函数具有 EXECU

    注意事项

    本文(2022年sql2k增加的Function的sqlbook的帮助SQL server]教程.docx)为本站会员(wj151****6093)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开