位置: 编程技术 - 正文

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 自定义函数 读取数据表)

  • 留抵税额做进项转出怎么做分录
  • 小型微利企业所得税率
  • 境外代扣代缴增值税
  • 企业所得税计提表模板
  • 报表申报错误怎么作废重报
  • 建行分期通
  • 残保金是谁支付给单位?
  • 员工全额承担社保账务怎么做?
  • 土地增值税多交了怎么处理
  • 职工伤残补助金被单位扣留违反什么法
  • 租赁公司运输费计入什么科目
  • 企业申请核定征收的要求
  • 退税勾选的发票账务处理
  • 销售货物类型
  • 税金及附加包括所得税费用吗
  • 车辆维修费
  • 未取得正式发票怎么整改
  • 营改增后二手房转让 一般计税 可以差额
  • 基金经费管理办法
  • 公司委托公司收款合法吗
  • 1697508230
  • 小规模纳税人增值税免征额
  • 小企业成本核算方法有哪几种
  • 多缴的企业所得税如何处理
  • 上月发生的费用本月报销记账
  • 库存现金的主要内容有哪些
  • 违约金条款的特点
  • win10怎么设置win7开始菜单
  • 分摊本月领用材料的成本差异
  • 如何在局域网内发布网页
  • aspnet_admin.exe进程是安全的吗 aspnet_admin进程信息查询
  • 公司注销做账
  • 质量事故责任书
  • 源码阅读技巧
  • 【2023-Pytorch-检测教程】手把手教你使用YOLOV5做电线绝缘子缺陷检测
  • 纳税人提供应税服务
  • 公允价值变动损益在利润表哪里
  • 为什么要划分等价类
  • ant design vue 表单
  • 公司处理固定资产车辆怎么开发票
  • 小程序uniapp怎么用
  • 税费的审计
  • 年报营业额填多少不纳税
  • css选择上一个兄弟
  • for循环语法结构是什么
  • python elasticsearch timeout
  • 如何利用税收经济效应实现税收的宏观调控目标
  • 甲企业持有乙企业股票的市价为920000
  • 股东入股资金如何记账
  • 小企业需要做计算机吗
  • 银行代发工资流失原因
  • 失控发票补缴税款后又被稽查
  • 已付款未认证发票怎么做账
  • 冲销以前年度主营业务成本
  • 长期待摊费用的最新账务处理
  • 认缴款和投资款区别
  • 房地产开发费用10%
  • 关于发票丢失的处罚
  • 本年利润每个月有余额吗
  • 为什么零售业只进不出呢
  • 汇率的差额如何处理
  • 应收账款和坏账准备的解题思路
  • innodb数据和索引文件
  • centos安装dig
  • win7系统硬盘分区类型
  • win10临时文件设置
  • 无法安装windows xp
  • jusched.exe是什么进程
  • win7系统怎么禁用win键
  • Android游戏开发读后感
  • android获取json数据
  • linux tcp keepalive
  • node wechat
  • javascript代码规范
  • jquery validator
  • js控制浏览器返回按钮
  • 重庆国税电子税务局官网登录入口网址
  • 四川国税网上办税
  • 广西怎么查社保记录
  • 中国进口车关税为什么那么贵
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设