用户自定义函数
自定义函数不能执行一系列改变数据库状态的操作,可以像系统函数在查询或存储过程等的程序中使用,也可以像相信过程一样能过 execute 命令来执行。自定义函数中存储了一个 Transact - SQL 例程可以返回一定的值。根据函数返回值形式的不同,将用户看定义函数分为三种类型:
( 1 ). 标量型函数:标量型函数返回一个确定类型的标量值,其返回值类型为除了 text, ntext , image ,cursor ,timestampt 和 table 类型外的其它数据类型。函数体语句定义在 begin - end 语句内,其中包含了可以返回值的 Transact - SQL 命令。
语法:
 create function [ owner_name ] function_name
( [ {@parameter_name [as ] scalar_parameter_data_type [ =default ] } [ ,n ] ])
 returns scalar_return_data_type
 [ with <function_option> [,n ] ]
 [ as ] 
 begin 
function_body
 return [ scalar_expression ] 
 end 
其中:
 < 1 > .function_option 有两个可选值:{encryption | schemabinding}
encryption: 加密选项,让 SQL Server 对系统表中有关 create function 的声明加密,以防止用户自定义函数作为 SQL Server 复制的一部分被发布。
schemabinding,计划绑定选项。将用户自定义函数绑定到它所引用的数据库对象,则函数所涉及的的数据库对象从此将不能被删除或修改,除非函数被删除或去掉此选项。应注意的是要绑定的数据库对象必须与函数在同一数据库中。
 < 2 > .owner_name: 指定用户自定义函数的所有者。
 < 3 > .function_name: 指定用户自定义函数的名称。
 < 4 > .database_name.owner_name.function_name 应是唯一的。
 < 5 > . @parameter_name : 定义一个式多个参数的名称,一个函数最多可以定义 1024 个参数,每个参数前用 @符号标明 ,参数的作用范围是整个函数,参数只能替代常量,不能替代表名,列名或其它数据库对象名称,用户自定义函数不支持输出参数。
 < 6 > .scalar_parameter_data_type: 指定标量参数的数据类型,除了 text, ntext , image , cursor,timestampt 和 table 类型外的其它数据类型。
 < 7 > .scalar_return_data_type: 指定标量返回值的数据类型,除了 text, ntext , image , cursor,timestampt 和 table 类型外的其它数据类型。
 < 8 > .scalar_expression: 指定标量型用户自定义函数返回的标量值表达式。
 < 9 > .function_body: 指定一系列的 Transact_SQL 语句它们决定了函数的返回值。

例:创建军工龄工资计算函数
 use taihang
 go 
 -- 创建函数 
 create function workyearwage( @hiredate datetime , @today datetime , @per_wage money )
 -- hiredate 表示雇佣期, today 表示当前日期,par_wage 表示每一年的工龄应得的工资额 
 returns money 
 as begin 
 declare @workyearwage money 
 set @workyearwage = ( year ( @today ) - year ( @hiredate )) * @per_wage 
 return ( @workyearwage )
 end -- 结束函数定义 
 go 
 -- 调用函数 
 select taihang.dbo.workyearwage( &apos; 1999-7-1 &apos; , getdate (), 15 )
 as work_year_wage
注意:以上的函数体可简写为:
 as begin 
 return (( year ( @today ) - year ( @hiredate )) * @per_wage )
 end 

( 2 ). 内嵌表值函数:以表的形式返回一个返回值,即它返回的是一个表。内嵌表值型函数没有由 begin -end 语句括起来的函数体,其返回的表由一个位于 return 子句中的 select 命令段从数据库中筛先出来。内嵌表值型函数功能相当于一个参数化的视图。
创建函数语法:
 create function [ owner_name ] function_name
( [ {@parameter_name [as ] scalar_parameter_data_type [ =default ] } [ ,n ] ])
 returns table 
 [ with <function_option> [,n ] ]
 [ as ] 
 return ( select - stmt)
其中:
 < 1 > . table : 批定返回值为一个表。
 < 2 > . select - stmt: 单个 select 语句,确定返回的表的数据。
例:创建返回所有订购某类产品的公司信息函数
 use taihang
 go 
 create function orderfirms( @productid varchar ( 30 ))
 -- productid 表示产品代号 
 returns table 
 as 
 return ( select * from products p
 where p.p_id = @productid )
 go 

( 3 ). 多语句表值型函数:可以看作标量型和内嵌表值型函数的结合体,它的返回值是一个表,但它和标量型函数一样有一个用 begin - end 语句括起来的函数体。返回值表中的数据是由函数体
语法:
 create function [ owner_name ] function_name
( [ {@parameter_name [as ] scalar_parameter_data_type [ =default ] } [ ,n ] ])
 returns @return_variable table < table_type_definition > 
 [ with <function_option> [,n ] ]
 [ as ] 
 begin 
function_body
 return end 
其中:
 < 1 > . < table_type_definition > :({column_definition | table_constraint} [ ,n ] )
 < 2 > . @return_variable : 一个 table 类型的变量,用于存储和累积返回的表中的数据行。

 4 . 修改用户自定义函数
 alter function : 此命令语法与 create function 相同,相当于重建。
 5 . 删除用户自定义函数
 drop function { [ owner_name ] function_name} [ ,n ] 
建议到企业管理器里修改,简单、方便。

SQL Server自定义函数( 转载于51CTO )的更多相关文章

  1. sql server 自定义函数的使用

    sql server 自定义函数的使用 自定义函数 用户定义自定义函数像内置函数一样返回标量值,也可以将结果集用表格变量返回 用户自定义函数的类型: 标量函数:返回一个标量值 表格值函数{内联表格值函 ...

  2. 13、SQL Server 自定义函数

    SQL Server 自定义函数 在SQL Server中不仅可以使用系统函数(如:聚合函数,字符串函数,时间日期函数等)还可以根据需要自定义函数. 自定义函数分为标量值函数和表值函数. 其中,标量值 ...

  3. SQL Server 自定义函数(Function)——参数默认值

    sql server 自定义函数分为三种类型:标量函数(Scalar Function).内嵌表值函数(Inline Function).多声明表值函数(Multi-Statement Functio ...

  4. 也来谈谈SQL SERVER 自定义函数~

    在使用SQL SERVER 数据库的时候,函数大家都应该用过,简单的比如 系统聚合函数 Sum(),Max() 等等.但是一些初学者编写自定义函数的时候,经常问起什么是表值函数,什么是标量值函数. 表 ...

  5. sql server自定义函数学习笔记

    sql server中函数分别有:表值函数.标量函数.聚合函数.系统函数.这些函数中除系统函数外其他函数都需要用户进行自定义. 一.表值函数 简单表值函数 创建 create function fu_ ...

  6. SQL server 自定义函数FUNCTION的使用

    原文链接:https://blog.csdn.net/lanxingbudui/article/details/81736402 前言:        在SQL server中不仅可以可以使用系统自带 ...

  7. sql server 自定义函数

    create function 函数名 (@pno int) returns int as begin declare @a int if not exists(select * from perso ...

  8. SQL SERVER 自定义函数 整数转成指定长度的16进制 转换成指定长度的16进制 不足补0

    最近做项目扩展的时候,遇到问题就是将整型转换成指定长度的16进制 刚开始就是直接使用 cast(12 as varbinary(4))但是发现这个不能解决我的问题 所以就上网搜了一下,然后改了改,下面 ...

  9. SQL SERVER 自定义函数 split

    Create function [dbo].[split] ( ), ) ) )) as begin declare @i int set @SourceSql=rtrim(ltrim(@Source ...

随机推荐

  1. DC DC電路電感的選擇

    注:只有充分理解電感在DC/DC電路中發揮的作用,才能更優的設計DC/DC電路.本文還包括對同步DC/DC及異步DC/DC概念的解釋.   DCDC電路電感的選擇 簡介 在開關電源的設計中電感的設計為 ...

  2. library cache lock

    SESSION 34 执行存储过程: SESSION 43 编译存储过程: SESSION 25 删除存储过程: 1.查询查看library cache lock等待事件的相关会话 SQL> s ...

  3. CentOS 7 ARM 版发布:支持树莓派2/香蕉派/CubieTruck

    CentOS 7 ARM 版发布:支持树莓派2/香蕉派/CubieTruck 来自CentOS团队的Karanbir Singh很高兴地宣布,面向ARM硬件架构的CentOS 7 Linux已经正式发 ...

  4. 【转】(DT系列五)Linux kernel 是怎么将 devicetree中的内容生成plateform_device

    原文网址:http://www.cnblogs.com/biglucky/p/4057495.html Linux kernel 是怎么将 devicetree中的内容生成plateform_devi ...

  5. Hackerrank 2020 February 2014 解题报告

    Hackerrank 2020 February 2014 解题报告 比赛链接 Sherlock and Watson (20分) 题意:给定一个数组,向右平移K次,然后有Q个询问,问第x位置上是几 ...

  6. selenium webdriver python 元素操作

    常用操作 click 点击某个元素 driver.find_element_by_id(“su”).click()   clear driver.find_element_by_id(“kw”).cl ...

  7. Java高级特性之反射学习总结

    老规矩我们还是先提出几个问题,一门技术必然要能解决一定的问题,才有去学习掌握它的价值 一. 什么是反射? 二.反射能做什么? 一. 什么是反射? 用在Java身上指的是我们可以于运行时加载.探知.使用 ...

  8. iOS--导航栏样式

    push返回按钮样式: UIBarButtonItem *item = [[UIBarButtonItem alloc] initWithTitle:@"" style:UIBar ...

  9. Android Studio 2.1.x 关联SDK API Source

    问题: 看图=>,当在android studio里ctrl+鼠标左键查看例如: TextUtils.isEmpty(content);这段代码的isEmpty方法的实现的时候经常就跑到如图所示 ...

  10. Django 邮件推送 解决附件中文名字乱码

    Django邮件功能,详情可看官方文档(https://docs.djangoproject.com/en/1.10/topics/email/). 最近做这个功能时遇到的问题,发送附件,收到后中文名 ...