sqlserver自定义函数【粘】
|
用户定义自定义函数像内置函数一样返回标量值,也可以将结果集用表格变量返回
用户自定义函数的类型: 标量函数:返回一个标量值 表格值函数{内联表格值函数、多表格值函数}:返回行集(即返回多个值) 1、标量函数 Create function 函数名(参数) Returns 返回值数据类型 [with {Encryption | Schemabinding }] [as] begin SQL语句(必须有return 变量或值) End Schemabinding :将函数绑定到它引用的对象上(注:函数一旦绑定,则不能删除、修改,除非删除绑定) Create function AvgResult(@scode varchar(10)) Returns real As Begin Declare @avg real Declare @code varchar(11) Set @code=@scode + ‘%’ Select @avg=avg(result) from LearnResult_baijiali Where scode like @code Return @avg End 执行用户自定义函数 select 用户名。函数名 as 字段别名 select dbo.AvgResult(‘s0002’) as result 用户自定义函数返回值可放到局部变量中,用set ,select,exec赋值 declare @avg1 real ,@avg2 real ,@avg3 real select @avg1= dbo.AvgResult(‘s0002’) set @avg2= dbo.AvgResult(‘s0002’) exec @avg3= dbo.AvgResult ‘s0002’ select @avg1 as avg1 ,@avg2 as avg2 ,@avg3 as avg3 函数引用 create function code(@scode varchar(10)) returns varchar(10) as begin declare @ccode varchar(10) set @scode = @scode + ‘%’ select @ccode=ccode from cmessage where ccode like @scode return @ccode end select name from class where ccode = dbo.code(‘c001’) 2、表格值函数 a、 内联表格值函数 格式: create function 函数名(参数) returns table [with {Encryption | Schemabinding }] as return(一条SQL语句) create function tabcmess(@code varchar(10)) returns table as return(select ccode,scode from cmessage where ccode like @ccode) b、 多句表格值函数 create function 函数名(参数) returns 表格变量名table (表格变量定义) [with {Encryption | Schemabinding }] as begin SQL语句 end 多句表格值函数包含多条SQL语句,至少有一条在表格变量中填上数据值 表格变量格式 returns @变量名 table (column 定义| 约束定义 [,…]) 对表格变量中的行可执行select,insert,update,delete , 但select into 和 insert 语句的结果集是从存储过程插入。 Create function tabcmessalot (@code varchar(10)) Returns @ctable table(code varchar(10) null,cname varchar(100) null) As Begin Insert @ctable Select ccode,explain from cmessage Where scode like @code return End Select * from tabcmessalot(‘s0003’) 来自:http://hi.baidu.com/datachina/blog/item/801def0366c4e7ea09fa9344.html 下面是我从别的地方弄的一个例子,浅显易懂: 编写一个函数,该函数,可以通过输入借书时间来判断是否到期,当借阅时间大于30天,返回已经过期;否则返回还未到期。 CREATE FUNCTION IsDateout(@BDate datetime) 复制代码代码如下:
CREATE FUNCTION dbo.Foo() RETURNS int AS BEGIN declare @n int select @n=3 return @n END 内嵌表值函数示例 复制代码代码如下:
CREATE FUNCTION dbo.Foo() RETURNS TABLE AS return select id, title from msgs 内嵌表值函数只有一个 select 语句。 复制代码代码如下:
CREATE FUNCTION fn_FindReports (@InEmpId nchar(5)) RETURNS @retFindReports TABLE (empid nchar(5) primary key, empname nvarchar(50) NOT NULL, mgrid nchar(5), title nvarchar(30)) ... 注意其 RETURNS 部分。 |
sqlserver自定义函数【粘】的更多相关文章
- sqlserver自定义函数的创建与调用
sqlserver中有系统提供的函数,像avg.sum.getdate()等,用户还可以自定义函数. 用户自定义的函数包括:标量函数和表值函数,其中标量函数和系统函数的用法一样,表值函数根据主体的定义 ...
- sqlserver自定义函数与存储过程的区别 实例详解
分享下sql server自定义函数与存储过程的区别,一起来学习下. 一.自定义函数: 1. 可以返回表变量 2. 限制颇多,包括 不能使用output参数: 不能用临时表: 函数内部的操作不能影响到 ...
- SQLServer自定义函数简单演示
CREATE FUNCTION [ schema_name. ] function_name ( [ { @parameter_name [ AS ][ type_schema_name. ] par ...
- Sqlserver自定义函数Function
一.FUNCTION: 在sqlserver2008中有3中自定义函数:标量函数/内联表值函数/多语句表值函数,首先总结下他们语法的异同点: 同点:1.创建定义是一样的: ...
- sqlserver自定义函数
标量函数 RETURNS 子句指定一种标量数据类型,则函数为标量值函数. 语法 Create function 函数名(参数) Returns 返回值数据类型 [with {Encryption | ...
- sqlserver自定义函数(标量值函数,表值函数)
用户自定义的函数有两类:表值函数.标量值函数. 表值函数:返回值是数据表的函数 调用方式 select b.* from tableA a accross apply Fun_BiaoZhiFun ...
- SqlServer自定义函数Function中调用with as
SET QUOTED_IDENTIFIER ON 标识符可以由双引号分隔,而文字必须由单引号分隔 SET QUOTED_IDENTIFIER OFF 标识符不可加引号,且必须遵守所有 Transact ...
- Sqlserver中存储过程,触发器,自定义函数(二)
Sqlserver中存储过程,触发器,自定义函数: 自定义函数:1.函数类型:2.函数的参数和返回值: 1.函数类型:标量值函数,返回的是一个标量值表值函数:内联表值函数:多语句表值函数. 标量值函数 ...
- Sqlserver中存储过程,触发器,自定义函数(一)
Sqlserver中存储过程,触发器,自定义函数 1.存储过程有关内容存储过程的定义:存储过程的分类:存储过程的创建,修改,执行:存储过程中参数的传递,返回与接收:存储过程的返回值:存储过程使用游标. ...
随机推荐
- AngularJS 整理资料
AngularJS是Google开源的一款JavaScript MVC框架,弥补了HTML在构建应用方面的不足,其通过使用指令(directives)结构来扩展HTML词汇,使开发者可以使用HTML来 ...
- Java Concurrency - ThreadLocal, 本地线程变量
共享数据是多线程应用最常见的问题之一,但有时我们需要为每个线程保存一份独立的变量.Java API 提供了 ThreadLocal 来解决这个问题. 一个 ThreadLocal 作用的例子: imp ...
- SSRS:之为用户“NT AUTHORITY\NETWORK SERVICE”授予的权限不足,无法执行此操作。 (rsAccessDenied)
错误信息: 为用户"NT AUTHORITY\NETWORK SERVICE"授予的权限不足,无法执行此操作. (rsAccessDenied) 如图: 解决方案之检查顺序: 1. ...
- UpdatePanel中执行js
在UpdatePanel中,直接使用Page.ClientScript.RegisterStartupScript的方式执行javascript,会导致无法执行.原因可能是因为RegisterStar ...
- kettle
Kettle(中文名称叫水壶)是一款ETL工具,纯java编写,可以在Window.Linux.Unix上运行,绿色无需安装,数据抽取高效稳定.Kettle家族包括4个产品:Spoon.Pan.CHE ...
- DOS批处理命令-CMD命令
CMD命令是重新开始一个命令解析器的实例.当然,他的功能并不止这么简单. Windows コマンド インタープリターの新しいインスタンスを開始します. 语法结构 CMD [/A | /U] [/Q] ...
- 在SQL 2012中使用和Oracle 一样的序列
使用过Oracle的都知道,Oracle中的自增是靠序列来完成的,在一定程度上蛮方便的.现在SQL 2012中也有序列了.来看看怎么做的吧! SQL Server 现在将序列当成一个对象来实现,创建一 ...
- 实例介绍Cocos2d-x物理引擎:HelloPhysicsWorld
我们通过一个实例介绍一下,在Cocos2d-x 3.x中使用物理引擎的开发过程,熟悉这些API的使用.这个实例的运行后的场景,当场景启动后,玩家可以触摸点击屏幕,每次触摸时候,就会在触摸点生成一个新的 ...
- CentOS 7 下Docker的安装
笔者是刚入行1年的新鸟,近期公司开始推Docker技术.这个系列的文章都是基于CentOS7系统下进行讲解的. Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及 ...
- 升级NppAstyle中的AstyleLib为最高版本
注:本文撰写时,NppAstyle的最高版本为0.10.02.14(更新于2013-04-08),Astyle的最高版本为2.05.1(更新于2014-12-11). Astyle是一个很好的代码格式 ...