sqlserver中有系统提供的函数,像avg、sum、getdate()等,用户还可以自定义函数。

用户自定义的函数包括:标量函数和表值函数,其中标量函数和系统函数的用法一样,表值函数根据主体的定义方式又可分为内嵌函数和多语句函数。

下面一一介绍语法。

标量函数:

 Create function 函数名(参数)
Returns 返回值数据类型
[with {Encryption | Schemabinding }]
[as]
begin
SQL语句(return变量)
End
注:Schemabinding将函数绑定到它引用的对象上(注:函数一旦绑定,则不能删除、修改,除非删除绑定)

表值函数-内嵌函数:

 create function 函数名(参数)
returns table
[with {Encryption | Schemabinding }]
as
return(一条SQL语句)

表值函数-多语句函数:

 create function 函数名(参数)
returns 表变量名 table (表变量定义)
[with {Encryption | Schemabinding }]
as
begin
SQL语句
end

下面介绍使用方法,使用前先创建几个表用于测试,表如下:

 CREATE TABLE [dbo].[Classes](
[ID] [int] IDENTITY(1,1) NOT NULL primary key,
[ClassName] [nvarchar](50) NOT NULL,
[CreateTime] [datetime] NOT NULL
); CREATE TABLE [dbo].[Students](
[ID] [int] IDENTITY(1,1) NOT NULL primary key,
[Name] [nvarchar](50) NOT NULL,
[ClassId] [int] NOT NULL,
[Age] [int] NOT NULL,
[CreateTime] [datetime] NOT NULL
); CREATE TABLE [dbo].[Courses](
[ID] [int] IDENTITY(1,1) NOT NULL primary key,
[Name] [nvarchar](50) NOT NULL,
[Credit] [float] NOT NULL
); CREATE TABLE [dbo].[StuScores](
[ID] [int] IDENTITY(1,1) NOT NULL primary key,
[StuId] [int] NOT NULL,
[CourseId] [int] NOT NULL,
[Score] [int] NOT NULL
);

例子如下:

 --标量函数:返回某个班级的人数
create function F_GetSomeClassStuCount(@classId int)
returns int
as
begin
declare @rtnCount int
select @rtnCount=count(*) from Students where ClassId=@classId
return @rtnCount
end; select dbo.F_GetSomeClassStuCount(1); --表值函数-内嵌函数:返回某个班级的人员信息 注意此处不需begin-end包裹
create function F_GetSomeClassStruInfo(@classId int)
returns table
as
return (select * from Students where ClassId=@classId); select * from dbo.F_GetSomeClassStruInfo(1); --表值函数-多语句函数:返回某个学生的成绩
create function F_GetSomStuScore(@stuName nvarchar(50))
returns @tmpTb table(
StuName nvarchar(50),
CourseName nvarchar(50),
Score int
)
as
begin
insert into @tmpTb
select s.Name as StuName,c.Name as CourseName,ss.Score
from StuScores ss
left join Students s on ss.StuId=s.ID
left join Courses c on ss.CourseId=c.ID
where s.Name=@stuName
return
end; select * from F_GetSomStuScore('杨过')

sqlserver自定义函数的创建与调用的更多相关文章

  1. SQLServer自定义函数简单演示

    CREATE FUNCTION [ schema_name. ] function_name ( [ { @parameter_name [ AS ][ type_schema_name. ] par ...

  2. Sqlserver自定义函数Function

    一.FUNCTION: 在sqlserver2008中有3中自定义函数:标量函数/内联表值函数/多语句表值函数,首先总结下他们语法的异同点: 同点:1.创建定义是一样的:                ...

  3. sqlserver自定义函数【粘】

     用户定义自定义函数像内置函数一样返回标量值,也可以将结果集用表格变量返回 用户自定义函数的类型: 标量函数:返回一个标量值 表格值函数{内联表格值函数.多表格值函数}:返回行集(即返回多个值) 1. ...

  4. MySQL 存储函数的创建、调用、查找

    MySQL存储函数(自定义函数),函数一般用于计算和返回一个值,可以将经常需要使用的计算或功能写成一个函数 1.创建存储函数:使用 create function关键字 2.调用存储函数: 3.示例: ...

  5. sqlserver自定义函数与存储过程的区别 实例详解

    分享下sql server自定义函数与存储过程的区别,一起来学习下. 一.自定义函数: 1. 可以返回表变量 2. 限制颇多,包括 不能使用output参数: 不能用临时表: 函数内部的操作不能影响到 ...

  6. sql自定义函数及C#中调用

    1.在C#中调用sql自定义函数 1.1 标量值函数 sql语句调用 select  dbo.GetClassIDWithName(1) string strSql = string.Format(& ...

  7. sqlserver自定义函数(标量值函数,表值函数)

    用户自定义的函数有两类:表值函数.标量值函数. 表值函数:返回值是数据表的函数 调用方式 select  b.*  from tableA a accross apply Fun_BiaoZhiFun ...

  8. SqlServer自定义函数Function中调用with as

    SET QUOTED_IDENTIFIER ON 标识符可以由双引号分隔,而文字必须由单引号分隔 SET QUOTED_IDENTIFIER OFF 标识符不可加引号,且必须遵守所有 Transact ...

  9. oracle 函数的创建和调用

    以下已经测试通过 创建函数: create or replace function get_annual_sal(in_name varchar2) return number is annual_s ...

随机推荐

  1. 如何启动另一个Activity

    --------siwuxie95 首先为res->layout下my_layout.xml 的Design添加一个Button,进入Text, android:text 修改为:启动另一个Ac ...

  2. JDK的安装及部署配置(配图解)

    JDK的安装及部署配置 双击安装文件,出现如下界面 点击[下一步]出现如下界面,更改安装路径(建议安装至D盘), 点击[下一步],出现如下界面,修改文件夹名. 点击[确定],耐心等待 直至出现如下界面 ...

  3. python学习之——计算给出代码中注释、代码、空行的行数

    题目:计算给出代码中注释.代码.空行的行数 来源:网络 思路:注释行以 ‘#’开头,空行以 ‘\n’ 开头,以此作为判断 def count_linenum(fname): fobj = open(f ...

  4. 团队项目作业:利用NABCD模型进行竞争性需求分析

    NABC正是这样的一套框架,当你试图提出一项崭新的提案之际,它能够提供四个思维基点,令你的商业策划具备天马行空的基础. 具体来说,NABC是四个关键词的首字母缩写- Need(需求)-现在市场上未被满 ...

  5. 小希的数表2(用的for循环)

    #include<iostream> 02.#include<algorithm> 03.using namespace std; 04. 05.bool cmp(int a, ...

  6. 委托 在其他类中修改form中的控件属性

    通常情况下,我们需要在其他业务类中将提示信息时时显示到主界面上,可以通过以下方式 Form1.cs using System; ; i < ; i++) {                 cb ...

  7. rocksdb编译测试的正确姿势

    需要先安装 gflags 在进行 make db_bench 不然运行 db_bench 会出现 Please install gflags to run rocksdb tools 错误 bench ...

  8. EasyUI Combobox设定默认值

    $(function () { $('#Select6').combobox({ onLoadSuccess: function () { var data = $('#Select6').combo ...

  9. Gossip protocol(zz)

    Gossip protocol 这是一系列用于P2P的通信协议.简单来说,就是模拟人类社会中流言传播的方式.每个节点随机地把消息发给它的邻居,接到消息的节点,如果之前没收到这个消息,则会继续随机地转发 ...

  10. 递推 N矩形问题

    Description 给你一个高为n ,宽为m列的网格,计算出这个网格中有多少个矩形,下图为高为2,宽为4的网格. Input 第一行输入一个t, 表示有t组数据,然后每行输入n,m,分别表示网格的 ...