首页 > 其他 > 详细

存储过程

时间:2019-01-10 18:16:29      阅读:175      评论:0      收藏:0      [点我收藏+]
技术分享图片
if(exists (select 1 from sys.objects where name=proc_out)) --用于判断改存储过程是否存在
    drop proc proc_out
GO    
CREATE PROC proc_out
    @id1 int out,     --out    可以传进,可以传出
    @id2 int output   --output 不用传进,也不可传进,可以传出,
AS
declare @id3 int
BEGIN
    if @id1 = 0
        set @id1=1
    select @id2=2;
    select @id3=3;
    return @id3;    -- 返回值
END        
--调用方法
declare @id1 int,@id2 int,@id3 int
set @id1=100
exec @id3=proc_out @id1 out, @id2 output
select @id1,@id2,@id3
out,output,return 区别
技术分享图片
if(exists (select 1 from sys.objects where name=Proc_UPDATE))
    drop proc Proc_UPDATE
GO
Create Proc Proc_UPDATE
    @Id1 int,
    @Id2 int
AS
BEGIN
    BEGIN tran;   --开启事务
    BEGIN try
        update [studentinfo_2019] set Name=Name + @Id1 where Id=@Id1
        update [studentinfo_20191] set Name=Name + @Id2 where Id=@Id2
        commit;    --完成事务
    END try
    BEGIN catch
    rollback;      --回滚事务
    END catch
END    
事务的使用
技术分享图片
if (exists(select * from  sys.objects where name=GetStudentByPage))
    drop proc GetStudentByPage
go 
create proc GetStudentByPage
    @pageIndex int,
    @pageSize int
as 
declare 
@startIndex int,
@endIndex int;
set @startIndex =  (@pageIndex-1)*@pageSize+1;
set @endIndex = @startIndex + @pageSize -1 ;
begin 
    select * from 
    (
        select *,row_number()over (order by Id)as number from studentinfo_2019  
    )t where t.number>=@startIndex and t.number<=@endIndex
end
分页

Set 和 Select  的区别

  set select
同时对多个变量同时赋值 不支持 支持
表达式返回多个值时 出错 将返回的最后一个值赋给变量
表达式未返回值 变量被赋null值 变量保持原值

存储过程

原文:https://www.cnblogs.com/Jacob-Wu/p/10251526.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!