首页 > 其他 > 详细

存储过程

时间:2016-03-28 16:43:56      阅读:208      评论:0      收藏:0      [点我收藏+]

存储过程必须是批处理中仅有的语句

语法:

Go   

create  Procedure  存储过程名

   @参数名  参数类型(int,string...)

   as

       if(@参数名)

           select @参数名=count(*) from 表名  where  ...

        else

            set @参数名=1000

 Go

1.只返回单一记录集的存储过程

create Procedure GetUserAccount
as
select * from UserAccount
go

-------------执行上面的存储过程----------------
exec GetUserAccount

--相当于执行了select 语句,返回数据集

2、没有输入输出的存储过程

create Procedure inUserAccount
as
insert into UserAccount (UserName,[PassWord],RegisterTime,RegisterIP) values(9,9,2013-01-02,9)
go

-------------执行上面的存储过程----------------

exec inUserAccount
--修改和插入都只是执行操作,不会返回任何数据

3、有返回值的存储过程

create Procedure inUserAccountRe
as
insert into UserAccount (UserName,[PassWord],RegisterTime,RegisterIP) values(10,10,2013-01-02,10)
return @@rowcount
go

-------------执行上面的存储过程----------------

exec inUserAccountRe
--返回执行多少行

4、有输入输出参数的存储过程

create Procedure GetUserAccountRe
@UserName nchar(20),
@UserID int output
as
if(@UserName>5)
select @UserID=COUNT(*) from UserAccount where UserID>25
else
set @UserID=1000
go

-------------执行上面的存储过程----------------

exec GetUserAccountRe 7,null

5、同时具有返回值、输入参数、输出参数的存储过程

create Procedure GetUserAccountRe1
@UserName nchar(20),
@UserID int output
as
if(@UserName>5)
select @UserID=COUNT(*) from UserAccount where UserID>25
else
set @UserID=1000
return @@rowcount
go

exec GetUserAccountRel 7 ,null

6、同时返回参数和记录集的存储过程

create Procedure GetUserAccountRe2
@UserName nchar(20),
@UserID int output
as
if(@UserName>5)
select @UserID=COUNT(*) from UserAccount where UserID>25
else
set @UserID=1000
select * from UserAccount
return @@rowcount
go

7、返回多个记录集的存储过程

create Procedure GetUserAccountRe3
as
select * from UserAccount
select * from UserAccount where UserID>5
go

-------------执行上面的存储过程----------------

exec GetUserAccountRe3

后台调用存储过程的代码  (仅作为参考)

 //同时具有返回值、输入参数、输出参数的存储过程GetUserAccountRe1
        public void runGetUserAccountRe1()
        {
            SqlCommand cmd = common("GetUserAccountRe1");
            // 创建参数 
            IDataParameter[] parameters = { 
                 new SqlParameter("@UserName", SqlDbType.NChar,20) , 
                 new SqlParameter("@UserID", SqlDbType.Int) ,
                 new SqlParameter("rval", SqlDbType.Int,4) 
             };
            // 设置参数类型 
            parameters[0].Value = "7";
            parameters[1].Direction = ParameterDirection.Output;  // 设置为输出参数 
            parameters[2].Direction = ParameterDirection.ReturnValue;  //设置为返回值
            // 添加参数 
            cmd.Parameters.Add(parameters[0]);
            cmd.Parameters.Add(parameters[1]);
            cmd.Parameters.Add(parameters[2]);
            con.Open();
            // 执行存储过程并返回影响的行数 
            Label1.Text = cmd.ExecuteNonQuery().ToString();
            con.Close();
            // 显示影响的行数和输出参数 
            Label1.Text += "-输出参数为:" + parameters[1].Value.ToString();
            Label1.Text += "-返回值为:" + parameters[2].Value.ToString();

        }

引用地址:http://www.cnblogs.com/knowledgesea/archive/2013/01/02/2841588.html

存储过程

原文:http://www.cnblogs.com/zmztya/p/5329494.html

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