位置: 编程技术 - 正文

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

  • 房屋租赁服务增值税税率是多少
  • 小微企业税收优惠政策2023年
  • 股权转让个人所得税如何计算
  • 企业利息收入需要交哪些税
  • 上市公司收购其他公司要多久
  • 统一企业员工
  • 住宿发票没有天数
  • 发票旁边的孔能撕吗
  • 自主研发全流程
  • 房地产土地使用权是无形资产吗
  • 利润和营收哪个更重要
  • 进项税转出主要内容包括
  • 没有收入的小规模纳税人可以无票入费用吗?
  • 企业预算管理为何要以企业战略,核心竞争力,风险为导向
  • 折扣销售的增值税处理方式
  • 无形资产发生减值的原因
  • 长期借款借方登记归还的本金和利息
  • 临时存款账户包括保证金账户
  • 增值税免税收入汇算清缴的时候填哪
  • 核定征收企业所得税的小型微利企业不得享受优惠政策
  • 企业注册资金需要拿钱出来吗
  • 第二季度的利润表报错了,怎么重新报
  • 非流动负债怎么巧记
  • 研发费用申报表汇算清缴怎么填
  • 推迟月经小窍门有民间土方法吗?
  • 收到发票未抵扣需要做账吗
  • 增值税及附加税是什么意思
  • ajax 返回
  • php如何实现分页功能
  • 计算机网络的定义
  • php5.5
  • 什么是AI工具
  • 作为大学生你能为国家安全贡献哪些力量论文
  • 尚品汇在哪
  • 终于见识到什么叫云横秦岭了
  • 材料明细帐
  • 应付职工薪酬中社保费怎么记账
  • /etc/rc.local添加内容
  • 材料暂估入库如何进行账务处理
  • 汽车上牌照的费用计入什么会计科目
  • 发票验真伪需要盖章吗
  • 残保金相关内容有哪些
  • 定期定额征收税款
  • 小企业会计准则主要按照什么计量
  • sql3表连接查询
  • 厂部管理人员的工资属于制造费用吗
  • 房地产企业拆迁补偿费入账要求
  • 技术服务费是否可以开具专票
  • 出售资产时递延所得税转回是全部收入吗
  • 利息支出税前扣除时点
  • 外购白酒继续生产白酒
  • 收到免费赠送的产品怎么做账
  • 企业的免税收入范围
  • 认缴制下实收资本可以一直为零吗
  • 劳务报酬现金流量
  • 会计记账中借方和贷方
  • mysql时间语句
  • oracle教程入门
  • sqlserver跨库查询sql回路问题
  • Windows Server 2008提升AD管理效率
  • linux/unix
  • win10正版系统禁止设置密码
  • ubuntu设置关闭按钮在右侧
  • centos安装图形oracle11g
  • linux vim 查找替换
  • win10如何打开defender
  • win10怎么关闭欢迎界面
  • WIN10安装教程
  • win10预览文件怎么显示内容
  • win10mobile下载官网
  • cocos2dx4.0教程
  • unity3d怎么移动物体
  • unity web端
  • javascript产生随机数
  • python xml 解析
  • 每月公积金900元交多少
  • 税务局追缴社保流程及办理期限
  • 个人无偿捐赠增值税
  • 在国税局工作属于什么职业
  • 工程增值税率从11%调整到9%
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设