关于ExecuteNonQuery执行存储过程的返回值
用到过ExecuteNonQuery()函数的朋友们在开发的时候肯定这么用过.
if(cmd.ExecuteNonQuery("xxxx")>0)
{
//执行成功!
}
else
{
//执行失败!
}
通过ExecuteNonQuery()的返回值来判断操作数据库的成功与否是可以的.但是要分情况.
1.ExecuteNonQuery() 不执行存储过程.
此时如果对数据库执行,插入,更新,删除操作,返回的是 受影响的行数.(及一个大于等于0的整数)
2.ExecuteNonQuery() 执行查询不返回影响的行数.
2.ExecuteNonQuery 执行存储过程.
[1].存储过程有返回值(传出参数)
(1).把数据库中受影响的行数赋给返回值,这是得到的返回值是受影响的函数(大于或等于0的整数).
(2).把某个值赋给返回值.
[2].存储过程没有返回值
执行成功后返回 -1.
(没有返回值的存储过程理应 返回 受影响的行数 (执行 增删改) 但是.但我们在ado.net中执行存储过程的时候,dotnet 自动为给了存储过程一个默认值:set nocount on;
所以给我们的感觉是执行存储过程默认返回 -1 )
============================================================================
1、执行存储过程 SqlConnection conn = new SqlConnection();//建立连接
conn.ConnectionString = Config.ConnStr;//连接字符串
conn.Open();//打开连接 SqlCommand cmd = new SqlCommand();//创建命令 cmd.Connection = conn;//指定连接 cmd.CommandText = "PRO_AAA";//存储过程名称 cmd.CommandType = CommandType.StoredProcedure;//指定命令的类型是存储过程 cmd.ExecuteNonQuery();//执行 conn.Close();//关闭连接
2、无返回
同上
3、获得返回结果:
指定一个参数,这个参数的方向(“Direction”)是“ReturnValue”。
MyCommand.Parameters.Add(new SqlParameter("@return", SqlDbType.Int)); MyCommand.Parameters["@return"].Direction = ParameterDirection.ReturnValue; MyCommand.ExecuteNonQuery(); Response.Write(MyCommand.Parameters["@return"].Value.ToString());
4、获得返回的表:
用SqlDataAdapter 执行Command,然后填充到表。
SqlCommand cmd = new SqlCommand("proc_3", con);//同上 cmd.CommandType = CommandType.StoredProcedure;//同上 SqlDataAdapter da = new SqlDataAdapter(cmd);//用SqlDataAdapter执行 DataTable table = new DataTable();//创建一张表 da.Fill(table);//填充表 return table;
参考:
【按:我是为了获得“Return返回值”搜索到第2和第3篇文章的,但是他们都没有找到解决办法,用的是OUTPUR输出。只有第一个是真正的解决办法。】
C#获取存储过程的 Return返回值和Output输出参数值 http://www.2cto.com/kf/201007/52892.html
ASP.NET调用存储过程并接收存储过程返回值
http://duanxifeng123.blog.163.com/blog/static/11542723201072112617414/?fromdm&fromSearch&isFromSearchEngine=yes
为什么存储过程总返回-1 取存储过程的值 取数据集
http://liu.wf.blog.163.com/blog/static/237887452009102335512300/
==========================================================================
发布时间:2008.05.07 04:40 来源:赛迪网 作者:小乔
|
【赛迪网-IT技术报道】存储过程可以有返回值,可以有传出参数。传出参数的数量没有限制,返回值只能有一个,并且执行return 以后,和其他语言的函数中一样,后面的语句就不会再执行了。所以该怎么用,还需要自己来权衡。
下面是获取返回值和传出参数的例子:
SqlConnection conn=new SqlConnection ( System.Configuration.ConfigurationManager.AppSettings["ConnectionString"]);
SqlCommand comm = new SqlCommand("ReturnValueTest",conn);
comm.Parameters.Add("@name", SqlDbType.NVarChar,100).Value ="chitu";
comm.Parameters.Add("@returnTest",SqlDbType.Int );
comm.Parameters.Add ("returnValue",SqlDbType.Int);
comm.Parameters["@returnTest"].Direction =ParameterDirection.Output;
comm.Parameters["returnValue"].Direction = ParameterDirection.ReturnValue;
comm.CommandType = CommandType.StoredProcedure;
conn.Open();
comm.ExecuteNonQuery();
conn.Close();
int a =(int) comm.Parameters["@returnTest"].Value;
int b = (int)comm.Parameters["returnValue"].Value;
返回值和传出参数彼此的作用还是无法替代的。(责任编辑:卢兆林)
|
=====================================================================
- C#获取存储过程的 Return返回值和Output输出参数值
- 2010-07-11 14:34:36 我来说两句
-
我要投稿
-
1.获取Return返回值
程序代码
//存储过程 //Create PROCEDURE MYSQL // @a int, // @b int //AS // return @a + @b //GO SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["LocalSqlServer"].ToString()); conn.Open(); SqlCommand MyCommand = new SqlCommand("MYSQL", conn); MyCommand.CommandType = CommandType.StoredProcedure; MyCommand.Parameters.Add(new SqlParameter("@a", SqlDbType.Int)); MyCommand.Parameters["@a"].Value = 10; MyCommand.Parameters.Add(new SqlParameter("@b", SqlDbType.Int)); MyCommand.Parameters["@b"].Value = 20; MyCommand.Parameters.Add(new SqlParameter("@return", SqlDbType.Int)); MyCommand.Parameters["@return"].Direction = ParameterDirection.ReturnValue; MyCommand.ExecuteNonQuery(); Response.Write(MyCommand.Parameters["@return"].Value.ToString());
2.获取Output输出参数值
程序代码
//存储过程 //Create PROCEDURE MYSQL // @a int, // @b int, // @c int output //AS // Set @c = @a + @b //GO SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["LocalSqlServer"].ToString()); conn.Open(); SqlCommand MyCommand = new SqlCommand("MYSQL", conn); MyCommand.CommandType = CommandType.StoredProcedure; MyCommand.Parameters.Add(new SqlParameter("@a", SqlDbType.Int)); MyCommand.Parameters["@a"].Value = 20; MyCommand.Parameters.Add(new SqlParameter("@b", SqlDbType.Int)); MyCommand.Parameters["@b"].Value = 20; MyCommand.Parameters.Add(new SqlParameter("@c", SqlDbType.Int)); MyCommand.Parameters["@c"].Direction = ParameterDirection.Output; MyCommand.ExecuteNonQuery(); Response.Write(MyCommand.Parameters["@c"].Value.ToString());
---------------------------------------------------------------------------------------------------------------
以下代码转自网络:
C#接收存储过程返回值:
public static int User_Add(User us) { int iRet; SqlConnection conn = new SqlConnection(Conn_Str); SqlCommand cmd = new SqlCommand("User_Add", conn); cmd.CommandType = CommandType.StoredProcedure; cmd.Parameters.AddWithValue("@UName", us.UName); cmd.Parameters.AddWithValue("@UPass", us.UPass); cmd.Parameters.AddWithValue("@PassQuestion", us.PassQuestion); cmd.Parameters.AddWithValue("@PassKey", us.PassKey); cmd.Parameters.AddWithValue("@Email", us.Email); cmd.Parameters.AddWithValue("@RName", us.RName); cmd.Parameters.AddWithValue("@Area", us.Area); cmd.Parameters.AddWithValue("@Address", us.Address); cmd.Parameters.AddWithValue("@ZipCodes", us.ZipCodes); cmd.Parameters.AddWithValue("@Phone", us.Phone); cmd.Parameters.AddWithValue("@QQ", us.QQ); cmd.Parameters.Add("@RETURN_VALUE", "").Direction = ParameterDirection.ReturnValue; try { conn.Open(); cmd.ExecuteNonQuery(); iRet = (int)cmd.Parameters["@RETURN_VALUE"].Value; } catch (SqlException ex) { throw ex; } finally { conn.Close(); } return iRet; }
C#接收存储过程输出参数:
public static decimal Cart_UserAmount(int UID) { decimal iRet; SqlConnection conn = new SqlConnection(Conn_Str); SqlCommand cmd = new SqlCommand("Cart_UserAmount", conn); cmd.CommandType = CommandType.StoredProcedure; cmd.Parameters.AddWithValue("@UID", UID); cmd.Parameters.Add("@Amount", SqlDbType.Decimal).Direction=ParameterDirection.Output; try { conn.Open(); cmd.ExecuteNonQuery(); iRet = (decimal)cmd.Parameters["@Amount"].Value; } catch (SqlException ex) { throw ex; } &n
- =========================================================
-
1、执行存储过程 SqlConnection conn = new SqlConnection();//建立连接
conn.ConnectionString = Config.ConnStr;//连接字符串
conn.Open();//打开连接 SqlCommand cmd = new SqlCommand();//创建命令 cmd.Connection = conn;//指定连接 cmd.CommandText = "PRO_AAA";//存储过程名称 cmd.CommandType = CommandType.StoredProcedure;//指定命令的类型是存储过程 cmd.ExecuteNonQuery();//执行 conn.Close();//关闭连接
2、无返回
同上
3、获得返回结果:
指定一个参数,这个参数的方向(“Direction”)是“ReturnValue”。
MyCommand.Parameters.Add(new SqlParameter("@return", SqlDbType.Int)); MyCommand.Parameters["@return"].Direction = ParameterDirection.ReturnValue; MyCommand.ExecuteNonQuery(); Response.Write(MyCommand.Parameters["@return"].Value.ToString());
4、获得返回的表:
用SqlDataAdapter 执行Command,然后填充到表。
SqlCommand cmd = new SqlCommand("proc_3", con);//同上 cmd.CommandType = CommandType.StoredProcedure;//同上 SqlDataAdapter da = new SqlDataAdapter(cmd);//用SqlDataAdapter执行 DataTable table = new DataTable();//创建一张表 da.Fill(table);//填充表 return table;
参考:
【按:我是为了获得“Return返回值”搜索到第2和第3篇文章的,但是他们都没有找到解决办法,用的是OUTPUR输出。只有第一个是真正的解决办法。】
C#获取存储过程的 Return返回值和Output输出参数值 http://www.2cto.com/kf/201007/52892.html
ASP.NET调用存储过程并接收存储过程返回值
http://duanxifeng123.blog.163.com/blog/static/11542723201072112617414/?fromdm&fromSearch&isFromSearchEngine=yes
为什么存储过程总返回-1 取存储过程的值 取数据集
http://liu.wf.blog.163.com/blog/static/237887452009102335512300/
流浪是注定的宿命; 漂泊是无尽的轮回。
1、执行存储过程 SqlConnection conn = new SqlConnection();//建立连接
conn.ConnectionString = Config.ConnStr;//连接字符串
conn.Open();//打开连接 SqlCommand cmd = new SqlCommand();//创建命令 cmd.Connection = conn;//指定连接 cmd.CommandText = "PRO_AAA";//存储过程名称 cmd.CommandType = CommandType.StoredProcedure;//指定命令的类型是存储过程 cmd.ExecuteNonQuery();//执行 conn.Close();//关闭连接
2、无返回
同上
3、获得返回结果:
指定一个参数,这个参数的方向(“Direction”)是“ReturnValue”。
MyCommand.Parameters.Add(new SqlParameter("@return", SqlDbType.Int)); MyCommand.Parameters["@return"].Direction = ParameterDirection.ReturnValue; MyCommand.ExecuteNonQuery(); Response.Write(MyCommand.Parameters["@return"].Value.ToString());
4、获得返回的表:
用SqlDataAdapter 执行Command,然后填充到表。
SqlCommand cmd = new SqlCommand("proc_3", con);//同上 cmd.CommandType = CommandType.StoredProcedure;//同上 SqlDataAdapter da = new SqlDataAdapter(cmd);//用SqlDataAdapter执行 DataTable table = new DataTable();//创建一张表 da.Fill(table);//填充表 return table;
参考:
【按:我是为了获得“Return返回值”搜索到第2和第3篇文章的,但是他们都没有找到解决办法,用的是OUTPUR输出。只有第一个是真正的解决办法。】
C#获取存储过程的 Return返回值和Output输出参数值 http://www.2cto.com/kf/201007/52892.html
ASP.NET调用存储过程并接收存储过程返回值
http://duanxifeng123.blog.163.com/blog/static/11542723201072112617414/?fromdm&fromSearch&isFromSearchEngine=yes
为什么存储过程总返回-1 取存储过程的值 取数据集
http://liu.wf.blog.163.com/blog/static/237887452009102335512300/
|
请发表评论