使用ADO.NET操作SQL Server存储过程

1、调用无输入输出参数的存储过程
创建无输入输出参数的存储过程
create   procedure  testProc 
as  
select  pub_id,title_id,price,pubdate
from  titles
where  price  is   not   null
order   by  pub_id
使用下面的程序来调用这个存储过程。在调用该存储过程时,需要告诉Command对象要调用的是存储过程。
< form id = " form1 "  runat = " server " >
    
< div >
    
< asp:DataGrid ID = " dg "  runat = " server "   />
    
</ div >
</ form >

SqlConnection Conn;
protected   void  Page_Load( object  sender, EventArgs e)
    {
        Conn 
=   new  SqlConnection( " server=localhost;database=pubs;uid=sa;pwd='' " );
        SqlCommand Comm 
=   new  SqlCommand( " testProc " , Conn);
        Comm.CommandType 
=  CommandType.StoredProcedure;
        Conn.Open();
        SqlDataReader dr 
=  Comm.ExecuteReader();
        dg.DataSource 
=  dr;
        dg.DataBind();
        Conn.Close();
    }

2、调用带输入输出参数的存储过程
CREATE   PROCEDURE  sp_CheckPass 
(
@CHKName   VARCHAR ( 30 ), @CHKPass   VARCHAR ( 30 ), @ISValid   VARCHAR ( 12 ) OUTPUT)
 
AS
IF   EXISTS ( SELECT  UserName  from  WebUsers  WHERE  UserName = @CHKName   and
UserPass
= @CHKPass )
    
SELECT   @ISValid = ' GOOD '
ELSE
    
SELECT   @ISValid = ' BAD '

SqlConnection Conn;
    
protected   void  Page_Load( object  sender, EventArgs e)
    {
        Conn 
=   new  SqlConnection( " server=localhost;database=pubs;uid=sa;pwd='' " );
        SqlCommand Comm 
=   new  SqlCommand( " sp_CheckPass " , Conn);
        Comm.CommandType 
=  CommandType.StoredProcedure;
        SqlParameter parm 
=  Comm.Parameters.Add( " @CHKName " , SqlDbType.VarChar,  30 );
        parm.Value 
=   " aa " ;
        parm 
=  Comm.Parameters.Add( " @CHKPass " , SqlDbType.VarChar,  30 );
        parm.Value 
=   " aa " ;
        parm 
=  Comm.Parameters.Add( " @ISValid " , SqlDbType.VarChar,  12 );
        parm.Direction 
=  ParameterDirection.Output;

        Conn.Open();
        SqlDataReader dr 
=  Comm.ExecuteReader();
        Response.Write(Comm.Parameters[
" @ISValid " ].Value);
        Conn.Close();
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值