位置: 编程技术 - 正文

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

  • 所得税汇算清缴招待费扣除标准
  • 分公司上交总公司营业款如何记账
  • 纳税期是多久
  • 小规模纳税人劳务派遣差额征税税率
  • 发票报销哪些要素不能少
  • 资产负债表怎么看营业收入
  • 个体户不刻公章违法吗
  • 预收贷方余额表示什么意思
  • 采购部差旅费会计分录怎么做
  • 小规模纳税人未开票收入填在哪里
  • 汇票退回会计分录怎么写
  • 经营杠杆系数分类
  • 存货暂估入账会引起存货账面价值发生增减变动吗
  • 维修变压器的维修方法
  • 投资税收抵免
  • 增值税专票可以重开吗
  • 多交的增值税怎么处理
  • 库管和车间工人哪个好
  • win7系统无法启用网络发现
  • qq能上,网页打不开怎么回事
  • win7音频服务未运行怎么办
  • 劳务公司的账务怎么做账
  • 保护地址是什么意思
  • php数组函数有哪些
  • php制作一个表单
  • 二手车增值税专用发票税率
  • 微软告诉你
  • 收到退款的会计分录
  • 建筑业主营业务收入二级科目有哪些
  • 分期付款购买固定资产折现率怎么算
  • 恩智浦杯官网
  • 衍生工具主要用途
  • ssm框架集成
  • php用在哪些方面
  • 基于ansible的运维平台
  • 一般纳税人销售给小规模纳税人
  • 未抵扣进项税额转出完整分录
  • 个体工商户没有收入要交税吗
  • mac的配置
  • 收到退回的企业所得税分录
  • 辞退员工补偿金计入什么科目
  • 银行收到电子承兑怎么查
  • 预收账款的核算处理
  • 个体户是什么概念
  • 收购企业如何做账
  • 固定资产没有折旧完要转走会计科目
  • 暂估入库的商品能出库吗
  • 购进无偿赠送
  • 记账凭证结算方式没出来
  • 享受所得税减免优惠的生产性外商投资企业包括
  • 递延收益的会计处理
  • 经营活动产生的现金流量净额越大越好吗
  • 小规模纳税人手工帐怎么做
  • 三栏式明细账适用于原材料吗
  • 期间费用率怎么算
  • 登记会计账簿的注意事项
  • mysql事件id100
  • mysql与c++相连
  • 利用rpm安装软件包时,应使用命令选项
  • mysql如何列转行
  • windowsandbox
  • solaris x86软件 sparc 区别
  • 注册表 命令
  • 电脑连接宽带时出错怎么办
  • Red Hat Enterprise Linux 5.X的图形安装教程
  • 查看linux的命令
  • win7登录账号
  • Linux通过shell脚本创建SVN版本库简化创建过程
  • gpio接口
  • Python Flask-web表单使用详解
  • cocos2dx4.0教程
  • CCProgressTimer 进度条动画在cocos2dx+lua中的使用
  • css怎么控制图片位置
  • [置顶]游戏名:chivalry2
  • unity火球特效
  • jQuery Mobile和HTML5开发App推广注册页
  • Android系统启动负载均衡
  • 异地社保如何在本地使用医保
  • 智能财税证书含金量多少
  • 为什么增值税是销项税减进项税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设