SqlServer獲取存儲(chǔ)過程返回值的實(shí)例_Mssql數(shù)據(jù)庫(kù)教程
推薦:SQL普通表轉(zhuǎn)分區(qū)表的方法SQL普通表轉(zhuǎn)分區(qū)表的方法,需要的朋友可以參考一下
1.OUPUT參數(shù)返回值
CREATE PROCEDURE [dbo].[nb_order_insert](
@o_buyerid int ,
@o_id bigint OUTPUT
)
AS
BEGIN
SET NOCOUNT ON;
BEGIN
INSERT INTO [Order](o_buyerid )
VALUES (@o_buyerid )
SET @o_id = @@IDENTITY
END
END
存儲(chǔ)過程中獲得方法:
DECLARE @o_buyerid int
DECLARE @o_id bigint
EXEC [nb_order_insert] @o_buyerid,@o_id output
2.RETURN過程返回值
CREATE PROCEDURE [dbo].[nb_order_insert](
@o_buyerid int ,
@o_id bigint OUTPUT
)
AS
BEGIN
SET NOCOUNT ON;
IF(EXISTS(SELECT * FROM [Shop] WHERE [s_id] = @o_buyerid ))
BEGIN
INSERT INTO [Order](o_buyerid ) VALUES (@o_buyerid )
SET @o_id = @@IDENTITY
RETURN 1 — 插入成功返回1
END
ELSE
RETURN 0 — 插入失敗返回0 END
存儲(chǔ)過程中的獲取方法
DECLARE @o_buyerid int
DECLARE @o_id bigint
DECLARE @result bit
EXEC @result = [nb_order_insert] @o_buyerid ,o_id output
3.SELECT 數(shù)據(jù)集返回值
CREATE PROCEDURE [dbo].[nb_order_select](
@o_id int
)
AS
BEGIN
SET NOCOUNT ON;
SELECT o_id,o_buyerid FROM [Order]
WHERE o_id = @o_id
GO
存儲(chǔ)過程中的獲取方法
(1)、使用臨時(shí)表的方法
CREATE TABLE [dbo].[Temp](
[o_id] [bigint] IDENTITY(1,1) NOT FOR REPLICATION NOT NULL,
[o_buyerid] [int] NOT NULL
)
INSERT [Temp] EXEC [nb_order_select] @o_id
– 這時(shí) Temp 就是EXEC執(zhí)行SELECT 后的結(jié)果集
SELECT * FROM [Temp]
DROP [Temp] — 刪除臨時(shí)表
1.獲取Return返回值
SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["ConnStr"].ToString());
conn.Open();
SqlCommand MyCommand = new SqlCommand("nb_order", conn); //存儲(chǔ)過程名字
MyCommand.CommandType = CommandType.StoredProcedure; //指定類型為存儲(chǔ)過程
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(); //執(zhí)行存儲(chǔ)過程
Response.Write(MyCommand.Parameters["@return"].Value.ToString()); //取得return的返回值
2.獲取Output輸出參數(shù)值
SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["ConnStr"].ToString());
conn.Open();
SqlCommand MyCommand = new SqlCommand("nb_order", 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()); //指定取得存儲(chǔ)過程的返回值
C#接收存儲(chǔ)過程返回值:
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; //指定存儲(chǔ)過程 AddWithValue可以指定名稱和值,而Add需要指定名稱,類型,再給value
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; //指定輸出參數(shù)是返回值
try
{
conn.Open();
cmd.ExecuteNonQuery(); //執(zhí)行存儲(chǔ)過程
iRet = (int)cmd.Parameters["@RETURN_VALUE"].Value; //取得return的值
}
catch (SqlException ex)
{
throw ex;
}
finally
{
conn.Close();
}
return iRet;
}
C#接收存儲(chǔ)過程的輸出參數(shù):
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; //利用Add方法為其添加名稱,類型和輸出參數(shù)
try
{
conn.Open();
cmd.ExecuteNonQuery();
iRet = (decimal)cmd.Parameters["@Amount"].Value; //取得存儲(chǔ)過程中的輸出參數(shù)
}
catch (SqlException ex)
{
throw ex;
}
finally
{
conn.Close();
}
return iRet;
}
C#取得結(jié)果集:
string sqlw = string.Format("exec sp_UserInfo {0}", uid);
DataTable dsuser = SqlConn.GetDataSet(sqlw).Tables[0];
public static DataSet GetDataSet(string sql)
{
string connStr = System.Configuration.ConfigurationManager.ConnectionStrings["ConnStr"].ToString();
SqlConnection conn = new SqlConnection(connStr);
SqlCommand cmd = new SqlCommand(sql, conn);
SqlDataAdapter da = new SqlDataAdapter(cmd); //直接用SqlDataAdapter將結(jié)果集取出來放入dataset中
DataSet ds = new DataSet();
da.Fill(ds);
conn.Close();
cmd.Dispose();
return ds;
}
分享:sqlserver附加.mdf權(quán)限問題解決sqlserver附加.mdf權(quán)限問題解決,需要的朋友可以參考一下
- sql 語(yǔ)句練習(xí)與答案
- 深入C++ string.find()函數(shù)的用法總結(jié)
- SQL Server中刪除重復(fù)數(shù)據(jù)的幾個(gè)方法
- sql刪除重復(fù)數(shù)據(jù)的詳細(xì)方法
- SQL SERVER 2000安裝教程圖文詳解
- 使用sql server management studio 2008 無(wú)法查看數(shù)據(jù)庫(kù),提示 無(wú)法為該請(qǐng)求檢索數(shù)據(jù) 錯(cuò)誤916解決方法
- SQLServer日志清空語(yǔ)句(sql2000,sql2005,sql2008)
- Sql Server 2008完全卸載方法(其他版本類似)
- sql server 2008 不允許保存更改,您所做的更改要求刪除并重新創(chuàng)建以下表
- SQL Server 2008 清空刪除日志文件(瞬間日志變幾M)
- Win7系統(tǒng)安裝MySQL5.5.21圖解教程
- 將DataTable作為存儲(chǔ)過程參數(shù)的用法實(shí)例詳解
Mssql數(shù)據(jù)庫(kù)教程Rss訂閱編程教程搜索
Mssql數(shù)據(jù)庫(kù)教程推薦
- SQL Server 2008存儲(chǔ)結(jié)構(gòu)之GAM、SGAM介紹
- 揭秘SQL Sever中各種語(yǔ)句的完整語(yǔ)法
- 淺談深入淺出SQL嵌套SELECT語(yǔ)句
- sql2005 安裝教程 圖文
- SQL Server 索引介紹
- mssql server 2012(SQL2012)各版本功能對(duì)比
- 怎樣用壓縮技術(shù)給SQL Server備份文件瘦身
- 用人工智能自動(dòng)對(duì)SQL語(yǔ)句進(jìn)行重寫
- Sql Server 2008完全卸載方法(其他版本類似)
- 揭秘規(guī)范設(shè)計(jì)數(shù)據(jù)庫(kù)應(yīng)注意的14個(gè)技巧
猜你也喜歡看這些
- mysql 數(shù)據(jù)庫(kù) (基礎(chǔ)) 筆記
- Mysql兩種情況下更新字段中部分?jǐn)?shù)據(jù)的方法
- jdbc調(diào)用mysql存儲(chǔ)過程實(shí)現(xiàn)代碼
- mysql出現(xiàn)“Incorrect key file for table”處理方法
- 深入理解SQL的四種連接-左外連接、右外連接、內(nèi)連接、全連接
- MySQL筆記之系統(tǒng)信息函數(shù)詳解
- 基于mysql查詢語(yǔ)句的使用詳解
- 10大關(guān)系數(shù)據(jù)庫(kù)SQL注入工具一覽
- 基于ubuntu中使用mysql實(shí)現(xiàn)opensips用戶認(rèn)證的解決方法
- MySQL筆記之運(yùn)算符使用詳解
- 相關(guān)鏈接:
- 教程說明:
Mssql數(shù)據(jù)庫(kù)教程-SqlServer獲取存儲(chǔ)過程返回值的實(shí)例
。