c#调用 存储过程

调用1 :http://www.cnblogs.com/blsong/archive/2009/11/30/1613534.html

C# 源代码

 1          ///  <summary>
 2           ///  校验用户
 3           ///  </summary>
 4           ///  <param name="user"> 用户信息 </param>
 5           ///  <returns></returns>
 6          public  static  int VerifyUser(clsUser user)
 7         {
 8              int iRet;
 9              string sql = String.Format("EXECUTE VerifyUser @myVerifyReader OUTPUT,'{0}','{1}'",user.username,user.password);  // 执行的T-SQL串
10             SqlCommand scmd =  new SqlCommand(sql, conn);
11             scmd.Parameters.Add( new SqlParameter("@myVerifyReader",SqlDbType.Int));
12             scmd.Parameters["@myVerifyReader"].Direction = ParameterDirection.Output;
13              //
14 
15             DBOpen(conn);
16              // 在返回值上有问题
17             scmd.ExecuteNonQuery();
18             iRet = ( int)scmd.Parameters["@myVerifyReader"].Value;
19             DBClose(conn);
20              return iRet;
21         }


SQL SERVER存储过程

-- ----------------------------


/*
* VerifyUser 存储过程
* 用途:验证用户登陆
*/
CREATE  PROCEDURE VerifyUser
(
     @myVerifyReader  int OUTPUT,  -- 返回结果
     @username  varchar( 50),  -- 用户名
     @userpassword  varchar( 50)  -- 用户密码
)
AS
IF  EXISTS( SELECT  [ id ]  FROM  [ Users ]  WHERE username  =  @username  AND userpassword  =  @userpassword)
     SET  @myVerifyReader  =  0  -- 通过验证

ELSE  IF  EXISTS( SELECT  [ id ]  FROM  [ Users ]  WHERE username  =  @username)
     SET  @myVerifyReader  =  1  -- 用户存在,密码不正确
ELSE
     SET  @myVerifyReader  =  2  -- 用户不存在

RETURN   isnull( @myVerifyReader, 3)
-- -----------------------------------------------
GO

 

先简单写一下吧,就是这么用的。

摘自:http://www.cnblogs.com/lizhi/archive/2007/07/10/812336.html 

 

C#获取存储过程返回值和输出参数值 

 

 

怎样执行存储过程,返回一个记录集和一个返回值?

比如   
  CREATE   PROCEDURE     aaaa   
  (   
  @ret   int   OUTPUT   
  )   
    AS   
  select   *   from   table1   
  set   @ret=0   
    
    
  GO   
 怎么同时取到select的结果和@ret的返回值呢   
  高手支招!

 

try   something   like   the   following,   note,   you   have   to   close   Reader   first   
    
  cmd   =   new   SqlCommand("aaaa",conn);   
  cmd.CommandType   =   CommandType.StoredProcedure;   
  cmd.Parameters.Add("@ret",   SqlDbType.Int);   
  cmd.Parameters["@ret"].Direction   =   ParameterDirection.Output;   
    
  SqlDataReader   reader   =   cmd.ExecuteReader();   
  while   (reader.Read())   
  {   
      //   
  }   
    
  reader.Close();   
    
  int   ret   =   (int)cmd.Parameters["@ret"].Value; 

 

//我参照的是下面的代码

调用2 :http://blog.csdn.net/itblog/article/details/752869

CREATE PROC P_TEST
@Name VARCHAR(20),
@Rowcount INT OUTPUT
AS
BEGIN
 SELECT * FROM T_Customer WHERE NAME=@Name
 SET  @Rowcount=@@ROWCOUNT
END
GO
----------------------------------------------------------------------------------------
--存储过程调用如下:
----------------------------------------------------------------------------------------
DECLARE @i INT
EXEC P_TEST 'A',@i OUTPUT
SELECT @i
--结果
/*
Name       Address    Tel                  
---------- ---------- -------------------- 
A          Address    Telphone

(所影响的行数为 1 行)

            
----------- 
1

(所影响的行数为 1 行)
*/
----------------------------------------------------------------------------------------
--DotNet 部分(C#)
--WebConfig 文件:
----------------------------------------------------------------------------------------
......
 </system.web>
 
   <!-- 数据库连接字符串
   -->
 <appSettings>
      <add key="ConnectString" value="server=(local);User ID=sa;Password=;database=Test" />
</appSettings>
   
</configuration>
----------------------------------------------------------------------------------------
--C#代码:(用到两个测试控件,DataGrid1(用于显示绑定结果集合),Lable(用于显示存储过程返回单值)
----------------------------------------------------------------------------------------
//添加数据库引用
using System.Data.SqlClient;
......
 private void Page_Load(object sender, System.EventArgs e)
  {
   // 在此处放置用户代码以初始化页面
   String DBConnStr;
   DataSet MyDataSet=new DataSet();
   System.Data.SqlClient.SqlDataAdapter DataAdapter=new System.Data.SqlClient.SqlDataAdapter();
   DBConnStr=System.Configuration.ConfigurationSettings.AppSettings["ConnectString"];
   System.Data.SqlClient.SqlConnection myConnection = new System.Data.SqlClient.SqlConnection(DBConnStr);
   if (myConnection.State!=ConnectionState.Open) 
   {
    myConnection.Open();
   }   
   System.Data.SqlClient.SqlCommand myCommand = new System.Data.SqlClient.SqlCommand("P_Test",myConnection);
   myCommand.CommandType=CommandType.StoredProcedure;
   //添加输入查询参数、赋予值
   myCommand.Parameters.Add("@Name",SqlDbType.VarChar);
   myCommand.Parameters["@Name"].Value ="A";

   //添加输出参数
   myCommand.Parameters.Add("@Rowcount",SqlDbType.Int);
   myCommand.Parameters["@Rowcount"].Direction=ParameterDirection.Output;


   myCommand.ExecuteNonQuery();
   DataAdapter.SelectCommand = myCommand;

   if (MyDataSet!=null)
   {
     DataAdapter.Fill(MyDataSet,"table");
   }
   
   DataGrid1.DataSource=MyDataSet;
   DataGrid1.DataBind();
   //得到存储过程输出参数
   Label1.Text=myCommand.Parameters["@Rowcount"].Value.ToString();

   if (myConnection.State == ConnectionState.Open)
   {
    myConnection.Close();
   }

  }
----------------------------------------------------------------------------------------
运行以上代码即可(返回记录集合和存储过程返回值)

转载于:https://www.cnblogs.com/loveCloud/archive/2012/01/10/2318039.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值