位置: 编程技术 - 正文

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

  • 预交所得税分录怎么写
  • 上月社保未扣款怎么回事
  • 农机合作社项目复核报告
  • 开具红字增值税专用发票的条件
  • 增值税发票污染了能补开吗
  • 增值税组成计税价格包括消费税吗
  • 存货入账价值计算公式
  • 在建工程过程中取得收入怎么入账
  • 老板想提取销售公积金
  • 购入汽车
  • 公司购买东西怎么做分录
  • 行业协会需要办理税务登记证吗
  • 未交税金期末数
  • 工会发放员工福利的通知
  • 工程项目的业务流程
  • 本单位员工投稿怎么写
  • 现金流量表中现金流量净额怎么算
  • 哪些津贴免征个税
  • 公司仓库调拔结算会计分录.
  • 员工娱乐活动比赛项目
  • vue项目如何搭建
  • 高新技术企业研发
  • 商业承兑汇票到期兑现流程
  • 公司的现金管理规定
  • 招投标公司需要什么条件
  • 简易征收增值税一般纳税人怎么报税
  • Win11 Build 22449.1000 预览版发布(附更新修复已知问题汇总)
  • 以旧换新销项税额对企业采取以旧换新方式销售
  • phppublic function
  • 现金折扣的会计分录处理
  • 固定资产不计提折旧有什么影响
  • 工程建设质保金比例
  • 怎样取消红字
  • ssh非交互式登录
  • phpstudy命令行
  • apt-show-versions
  • bcdboot命令怎么用
  • 公司购进软件的账务处理
  • C语言中main函数的位置可以任意吗
  • 印花税核定征收比例取消了吗
  • 个体户个税计算公式
  • 土地出让合同的法律效力
  • 2020新个税申报流程
  • 交易性金融资产包括哪些项目
  • 应付帐款不用付了的分录怎么处理
  • 在建工程工伤保险延期费用计算
  • 计提印花税会计科目
  • 长期股权投资如何入账
  • 应交税费科目账务处理
  • 劳务派遣证验资
  • 董事会会议的召集程序
  • 企业所得税预缴2‰
  • 物业管理企业应具备哪些条件
  • 固定资产公司
  • sql删除查询结果
  • sql,join
  • wamp怎么用mysql
  • SQL语句实现表的创建
  • windows 地址解析命令
  • win7系统如何关闭系统自检
  • linux的安装
  • linux解析命令
  • win2000系统安装教程
  • browsercore.exe是什么
  • dx12不支持dx11解决办法
  • linux 禁用root
  • 进程lsass.exe
  • linux简明教程
  • jquery 点击按钮
  • node.js创建服务
  • 深入浅出python
  • 关于中秋节的古诗
  • android平台搭建
  • android中启动service的方法有
  • psi python
  • python 判断字符串编码
  • python中编写程序
  • 内蒙古国家税务总局电子税务局官网
  • 珠海选调生2021公告
  • 税收分类编码1080499
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设