位置: 编程技术 - 正文

SQL Function 自定义函数详解(sql 自定义字段)

编辑:rootadmin

推荐整理分享SQL Function 自定义函数详解(sql 自定义字段),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql怎么自定义数据类型,sql自定义,sql自定义函数如何使用,sql自定义函数的调用格式,sqlserver自定义函数教程,自定义sql语句,sql自定义函数如何使用,sql自定义,内容如对您有帮助,希望把文章链接给更多的朋友!

目录

产生背景(已经有了存储过程,为什么还要使用自定义函数)发展历史构成使用方法适用范围注意事项疑问 内容

产生背景(已经有了存储过程,为什么还要使用自定义函数)

与存储过程的区别(存在的意义):

1. 能够在select等SQL语句中直接使用自定义函数,存储过程不行。2. 自定义函数可以调用其他函数,也可以调用自己(递归)3. 可以在表列和 CHECK 约束中使用自定义函数来实现特殊列或约束4. 自定义函数不能有任何副作用。函数副作用是指对具有函数外作用域(例如数据库表的修改)的资源状态的任何永久性更改。函数中的语句唯一能做的更改是对函数上的局部对象(如局部游标或局部变量)的更改。不能在函数中执行的操作包括:对数据库表的修改,对不在函数上的局部游标进行操作,发送电子邮件,尝试修改 目录,以及生成返回至用户的结果集。存储过程没有此限制5. 函数只能返回一个变量。而存储过程可以返回多个

发展历史

SqlServer 之后都支持用户自定义函数

构成

在SQL Server 中根据函数返回值形式的不同将用户自定义函数分为三种类型:标量函数(Scalar Function)、内嵌表值函数(Inline Function)、多声明表值函数(Multi-Statement Function)标量函数:标量函数是对单一值操作,返回单一值。能够使用表达式的地方,就可以使用标量函数。像我们经常使用的left、getdate等,都属于标量函数。系统函数中的标量函数包括:数学函数、日期和时间函数、字符串函数、数据类型转换函数等内嵌表值函数:内嵌表值函数的功能相当于一个参数化的视图。它返回的是一个表,内联表值型函数没有由BEGIN-END 语句括起来的函数体。其返回的表由一个位于RETURN 子句中的SELECT 命令段从数据库中筛选出来。

作用

多声明表值函数:可以看作标量型和内嵌表值型函数的结合体。它的返回值是一个表,但它和标量型函数一样有一个用BEGIN-END 语句括起来的函数体,返回值的表中的数据是由函数体中的语句插入的。由此可见,它可以进行多次查询,对数据进行多次筛选与合并,弥补了内联表值型函数的不足。

使用方法

SQL Server 为三种类型的用户自定义函数 提供了不同的命令创建格式。

  (1) 创建标量型用户自定义函数(Scalar functions) 其语法如下:

各参数说明如下:  owner_name :指定用户自定义函数的所有者。   function_name:指定用户自定义函数的名称。database_name.owner_name.function_name 应是惟一的。   @parameter_name:定义一个或多个参数的名称。一个函数最多可以定义 个参数每个参数前用“@”符号标明。参数的作用范围是整个函数。参数只能替代常量,不能替代表 名、列名或其它数据库对象的名称。用户自定义函数不支持输出参数。   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) 创建多声明表值型用户自定义函数

SQL Function 自定义函数详解(sql 自定义字段)

  其语法如下:

各参数说明如下:

  @return_variable :一个TABLE 类型的变量,用于存储和累积返回的表中的数据行。 其余参数与标量型用户自定义函数相同。

  在多声明表值型用户自定义函数的函数体中允许使用下列Transact-SQL 语句。 赋值语句(Assignment statements); 流程控制语句(Control-of-Flow statements); 定义作用范围在函数内的变量和 游标的DECLARE 语句; SELECT 语句; 编辑函数中定义的表变量的INSERT、 UPDATE 和DELETE 语句; 在函数中允许涉及诸如声明游 标、打开游标、关闭游标、释放游标这样的游标操作,对于读取游标而言,除非在FETCH 语句中使用INTO 从句来对某一变量赋值,否则不允许在函数中使用FETCH 语句来向客户端返回数据。此 外不确定性函数(Non-deterministic functions) 不能在用户自定义函数中使 用。所谓不确定性函数是指那些使用相同的调用参数在不同时刻调用得到的返回值不同的函数。这些函数如表-3 所示(全局变量也可以视为一种函数)。

适用范围

1. 只查询,不修改数据库的状态(修改、删除表中记录等)

2. 结果集需要通过递归等方法得到时,可以使用函数,函数比较灵活

3. 结果集需要直接被引用时,可以使用函数。需要对结果集进行再加工(指放在select语句中等),可以使用函数,函数可以嵌在select等sql语句中。

注意事项:

用户自定义函数不能用于执行一系列改变数据库状态的操作

在编写自定义函数时需要注意的:

对于标量函数:

1. 所有的入参前都必须加@

2. create后的返回,单词是returns,而不是return

3. returns后面的跟的不是变量,而是返回值的类型,如:int,char等。

4. 在begin/end语句块中,是return。

内嵌表值函数:

1. 只能返回table,所以returns后面一定是TABLE

2. AS后没有begin/end,只有一个return语句来返回特定的记录。

多语句表值函数:

1. returns后面直接定义返回的表类型,首先是定义表名,表明前面要加@,然后是关键字TABLE,最后是表的结构。

2. 在begin/end语句块中,直接将需要返回的结果insert到returns定义的表中就可以了,在最后return时,会将结果返回。

3. 最后只需要return,return后面不跟任何变量。

疑问:自定义函数不能修改数据库,但它可以调用存储过程,那么在自定义函数中调用一个有修改数据库的操作的存储过程,这个自定义函数能不能执行?

答:自定义函数只能调用扩展存储过程,但是SQL Server 的后续版本将删除该功能,不再支持扩展存储过程,所以应避免在开发中使用扩展存储过程。因此,可以得出结论是:实际开发中,函数不会去调用存储过程,也就无法对数据库进行修改操作了。

参考:

Sqlserver 自定义函数 Function使用介绍 一.FUNCTION:在sqlserver中有3中自定义函数:标量函数/内联表值函数/多语句表值函数,首先总结下他们语法的异同点:同点:1.创建定义是一样的:a,CREAT

SQl Function 创建函数实例介绍 在SQL中系统已为我们提供了很非常丰富的函数:例:聚会函数avg,sum,count,max,min日期函数:Day,Month,Year等等为我们日常开发节省很多时间但是有一些特殊需

SQL Server 利用触发器对多表视图进行更新的实现方法 其步骤就是:利用update操作触发器产生的2个虚拟表【inserted】用来存储修改的数据信息和【deleted】表,然后将对应的数据更新到对应数据表中的字段信

标签: sql 自定义字段

本文链接地址:https://www.jiuchutong.com/biancheng/318969.html 转载请保留说明!

上一篇:数据库 关键字一览表(数据库关键字有哪些)

下一篇:Sqlserver 自定义函数 Function使用介绍(sqlserver 自定义函数 读取数据表)

  • 12366纳税服务平台官网
  • 资产减值损失包括应收账款减值损失吗
  • 应付账款坏账了怎么处理
  • 缴纳所得税费用的会计分录
  • 职工薪酬会计准则
  • 准予在以后年度结转扣除的项目
  • 可转换公司债券权益成分和负债成分
  • 坏账已核销
  • 捐赠财产
  • 政府补贴项目账务怎么做
  • 员工入股怎么分成
  • 项目部分回款是什么意思
  • 外包会计处理
  • 接受投资者的无形资产
  • 原材料采用实际成本法核算
  • 跨行业能开发票吗
  • 增值税一般纳税人认定标准
  • 会议服务费怎么报价
  • 其他账簿印花税减免税优惠政策
  • 营改增后建筑业税率变化情况
  • 营改增通知规定的税收优惠政策
  • 自然人借款给企业的涉税风险
  • 小微企业季度所得税怎么计算
  • 企业所得税优惠事项包括哪些?
  • 电子发票能报税不
  • 退付手续费怎么操作
  • 票据背书怎么做账
  • 累进税率的特点是课税对象的数额越大,税率越
  • 固定资产公允价值变动会计处理
  • php缓存数据到内存
  • 白鹤芋的养殖方法和注意事项
  • 企业是根据什么来分类的
  • vue跳转到外部链接且带上参数
  • 临时存款账户怎么开户
  • 什么是动态表单
  • 药品进销差价的计算公式
  • 印花税的相关问题
  • vue3 $bus
  • 网络命令traceroute
  • php array search
  • 税款已缴纳可以作废申报吗
  • 人力资源服务的发票明细
  • 个税哪种申报方式好
  • 个税中的免税收入都包括什么
  • 注册资本认缴出资日期是什么意思
  • 应付职工薪酬在利润表哪里体现
  • 管理费用的纳税调整
  • 国库券利息收入属于企业所得税纳税调整项目
  • 物业公司代收代付租金要开发票吗
  • 融资租赁出租人与承租人之间形成债权债务关系
  • 加计抵减期末有余额怎么办
  • 非同一控制下企业合并发生的审计费
  • 电话费可以自动扣银行钱吗
  • 一次性收取一年的租金如何做分录
  • 加计抵减附加税怎么算
  • 研发费用扣除75%
  • 年度汇算清缴要补税怎么办
  • 资产减值损失冲减
  • w10桌面
  • win10每次开机都假死机
  • windows7光盘安装
  • mac下使用8086汇编
  • win8怎么一开机就进入桌面
  • fsma32.exe进程是什么文件 fsma32是什么进程
  • win10不兼容游戏名单
  • win7怎么禁用软件
  • 批处理文件的编写
  • 安卓退出界面
  • javascript中函数
  • jqurey+Jscex打造游戏力度条
  • Python高手之路第3版PDF下载
  • unity教程完整版
  • shaders initialized
  • javascript面向对象编程指南
  • python坑人代码
  • 国税局征收管理办法
  • 2023年四川城乡居民养老保险多少钱
  • 芜湖地税微机编码是什么
  • 2014年房产税征收标准
  • 城镇土地使用税优惠政策
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设