1定义变量

变量也分为本地及全局的两种,本地变量的名称都是以“@”为前缀,只有在本地当前的用户连接中才可以访问。全局的变量的名称都是以“@@”为前缀,一般都是系统的全局变量。
--简单赋值 
declare @a int
set @a=5 
print @a 
  
--使用select语句赋值 
declare @user1 nvarchar(50) 
select @user1='张三'
print @user1 
declare @user2 nvarchar(50) 
select @user2 = Name from ST_User where ID=1 
print @user2 
  
--使用update语句赋值 
declare @user3 nvarchar(50) 
update ST_User set @user3 = Name where ID=1 
print @user3

2创建临时表、表变量

临时表的创建是在Tempdb中,在一个数据库连接结束后或者由SQL命令DROP掉,才会消失,否则就会一直存在。临时表在创建的时候都会产生SQL Server的系统日志。在Tempdb中体现,在内存中分配,它们也支持物理的磁盘,但用户在指定的磁盘里看不到文件。

表变量也分为本地及全局的两种,本地表变量的名称都是以“@”为前缀,只有在本地当前的用户连接中才可以访问。全局的表变量的名称都是以“@@”为前缀,一般都是系统的全局变量。
--创建临时表
create table #DU_User1 
( 
     [ID] [int]  NOT NULL, 
     [Oid] [int] NOT NULL, 
     [Login] [nvarchar](50) NOT NULL, 
     [Rtx] [nvarchar](4) NOT NULL, 
     [Name] [nvarchar](5) NOT NULL, 
     [Password] [nvarchar](max) NULL, 
     [State] [nvarchar](8) NOT NULL
);
同普通表。

--从ST_User查询数据,填充至新生成的临时表 
select * into #DU_User2 from ST_User where ID<8

--定义表变量 
declare @t table
( 
    id int not null, 
    msg nvarchar(50) null
) 
同普通表。

3循环

declare @a int
declare @sum int
set @a=1 
set @sum=0
while @a<=100 
begin
    set @sum+=@a 
    set @a+=1 
end
print @sum

4条件

--if,else条件分支 
if(1+1=2) 
begin
    print '对'
end
else
begin
    print '错'
end
--begin,end相当于花括号

--when then条件分支 
declare @today int
declare @week varchar(3) 
set @today=3 
set @week=case
    when @today=1 then '星期一'
    when @today=2 then '星期二'
    when @today=3 then '星期三'
    when @today=4 then '星期四'
    when @today=5 then '星期五'
    when @today=6 then '星期六'
    when @today=7 then '星期日'
    else '值错误'
end
print @week

5存储过程

--创建带output参数的存储过程 
CREATE PROCEDURE PR_Sum 
    @a int, 
    @b int, 
    @sum int output
AS
BEGIN
    set @sum=@a+@b 
END
  
--创建Return返回值存储过程 
CREATE PROCEDURE PR_Sum2 
    @a int, 
    @b int
AS
BEGIN
    Return @a+@b 
END
      
--执行存储过程获取output型返回值 
declare @mysum int
execute PR_Sum 1,2,@mysum output
print @mysum 
  
--执行存储过程获取Return型返回值 
declare @mysum2 int
execute @mysum2= PR_Sum2 1,2 
print @mysum2

6自定义函数

函数的分类:
 
    1)标量值函数
 
    2)表值函数
 
        a:内联表值函数
 
        b:多语句表值函数
 
    3)系统函数
 
  
 
--新建标量值函数 
create function FUNC_Sum1 
( 
    @a int, 
    @b int
) 
returns int
as
begin
    return @a+@b 
end
  
--新建内联表值函数 
create function FUNC_UserTab_1 
( 
    @myId int
) 
returns table
as
return (select * from ST_User where ID<@myId) 
  
--新建多语句表值函数 
create function FUNC_UserTab_2 
( 
    @myId int
) 
returns @t table
( 
    [ID] [int] NOT NULL, 
    [Oid] [int] NOT NULL, 
    [Login] [nvarchar](50) NOT NULL, 
    [Rtx] [nvarchar](4) NOT NULL, 
    [Name] [nvarchar](5) NOT NULL, 
    [Password] [nvarchar](max) NULL, 
    [State] [nvarchar](8) NOT NULL
) 
as
begin
    insert into @t select * from ST_User where ID<@myId 
    return
end
  
--调用表值函数 
select * from dbo.FUNC_UserTab_1(15) 
--调用标量值函数 
declare @s int
set @s=dbo.FUNC_Sum1(100,50) 
print @s 
  
--删除标量值函数 
drop function FUNC_Sum1

7存储过程与函数比较

存储过程
    1. 不能返回表变量
    2. 限制少,可以执行对数据库表的操作,可以返回数据集
    3. 可以return一个标量值,也可以省略return
    存储过程一般用在实现复杂的功能,数据操纵方面
函数
    1. 可以返回表变量
    2. 限制颇多,包括
 
     不能使用output参数;
 
     不能用临时表;

     函数内部的操作不能影响到外部环境;
 
     不能通过select返回结果集;
 
     不能update,delete,数据库表;
    3. 必须return 一个标量值或表变量
    自定义函数一般用在复用度高,功能简单单一,争对性强的地方。

参考: