国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

探討SQL Server存儲過程

瀏覽:100日期:2023-11-02 18:33:56

A.;;;獲取存儲過程的ReturnValue值用了這么長時間的.NET了,竟然連怎么獲取存儲過程的返回值都不知道,真是失敗。 在網上搜了一下,就知道怎么用了。 Input 此參數只用于將信息從應用程序傳輸到存儲過程。 InputOutput 此參數可將信息從應用程序傳輸到存儲過程,并將信息從存儲過程傳輸回應用程序。 Output 此參數只用于將信息從存儲過程傳輸回應用程序。 ReturnValue 此參數表示存儲過程的返回值。SQL Server 的存儲過程參數列表中不顯示該參數。它只與存儲過程的 RETURN 語句中的值相關聯。

存儲過程為主鍵生成新值后,通常使用存儲過程中的 RETURN 語句返回該值,因此用來訪問該值的參數類型是 ReturnValue 參數。 ReturnValue 參數與其他類型的參數有一個重要的區別。通常,在 ADO.NET 中為 Command 對象配置的參數的順序并不重要。參數名稱只用來與存儲過程中相應的參數相匹配。但是,對于 ReturnValue 參數,它必須是列表中的第一個參數。 也就是說,為 Command 對象配置 ReturnValue 參數時,必須首先在代碼中配置該參數,這樣它才能獲取集合中的第一個數字索引。如果先配置任何其他參數,ReturnValue 參數將不能正常工作。 呵呵,這樣就可以了 args[0] = new SqlParameter('@RETURN_VALUE', SqlDbType.Int ); args[0].Direction = ParameterDirection.ReturnValue;

取回值的時候用args[0].Value.ToString()

B.獲得SQL-server存儲過程的返回值存儲過程為:

///<summary> ///c#code,獲得SQL-server存儲過程的返回值 ///<summary> SqlParameter[] sp = new SqlParameter[5]; sp[0]=new SqlParameter('@Name',SqlDbType.VarChar); sp[0].Value=this.TextName.Text; sp[1]=new SqlParameter('@Text',SqlDbType.Text); sp[1].Value=this.TextTxt.Text; sp[2]=new SqlParameter('@Comment',SqlDbType.Text); sp[2].Value=this.TextComment.Text; sp[3]=new System.Data.SqlClient.SqlParameter('ReturnValue',System.Data.SqlDbType.Int,4,System.Data.ParameterDirection.ReturnValue,false,0,0,string.Empty,DataRowVersion.Default,null); //參數'ReturnValue',System.Data.ParameterDirection.ReturnValue聲明此參數為返回值。 sp[4]=new SqlParameter('@Type',SqlDbType.Int); sp[4].Value=int.Parse(this.ClickBox.SelectedItem.Value); _SQL.ExecuteSP('us_styletextnew',sp); //使用sp[3].Value.ToString()即可!

存儲過程為:

CREATE PROCEDURE [dbo].[us_styletextnew]@id int=0,@Name varchar(50),@Text text,@Comment text,@Type intASSET NOCOUNT ONIF not EXISTS(SELECT [Name] FROM [dbo].[iStyle] WHERE [Name] = @Name)BEGININSERT INTO [dbo].[iStyle] ([Name], [Text], [Comment], [Type])VALUES (@Name,@Text,@Comment,@Type)SET @id = SCOPE_IDENTITY()ENDRETURN @idGO

希望對剛學存儲過程的朋友有點幫助!

用過SQLHelper的朋友,一定很懷疑SQLHelper怎么不能執行帶輸出、返回參數的存儲過程呢?請參考 http://blog.joycode.com/ghj/archive/2004/04/12/19015.aspx

此文并沒有做成相應的解決方法,所以這也是寫本文的一個出發點。原因值需要修改存儲過程中RETURN @id為SELECT @id,取值采用SqlHelper.ExecuteScalar 方法.其中原理并沒有違背SqlHelper.ExecuteScalar取第一行一列的值。

string aa= SqlHelper.ExecuteScalar(SqlHelper.CONN_STRING,'PRO_Table1_OPER',sp).ToString();

C.如何在存儲過程中引用別的存儲過程返回的表

1.;;;;一般的方法認為只有把存儲過程返回的值,寫入一個結構相同的 輔助表中,如下: create procedure proc1 as begin create table #t(...) --表結構同被調用存儲過程返回結果集的結構

insert #t exec proc2

select * from #t left join table on ... end go

2。還有一個方面就是用openrowset(不過就是速度不怎么樣) select * from openrowset('sqloledb' ,'Trusted_Connection=yes' ,'exec sp_who') -- 這里是你要調用的存儲過程參考文獻 :http://www.linkui.cn/read-20.htmlhttp://blog.joycode.com/ghj/archive/2004/04/12/19015.aspx

標簽: Sql Server 數據庫
主站蜘蛛池模板: 欧美无极品 | 国产在线视频专区 | 久久色精品 | 国产高清视频在线播放 | 手机在线观看亚洲国产精品 | 国产一级做a爰片在线看 | 免费区欧美一级毛片精品 | 一本一道久久综合狠狠老 | 精品少妇一区二区三区视频 | 日本在线观看一级高清片 | 国产欧美日韩图片一区二区 | 国产激情视频在线 | 在线视频欧美日韩 | 国产成人久久精品麻豆二区 | 91视频久久 | 久久精品免费全国观看国产 | 黄色三级日韩 | 另类亚洲孕妇分娩网址 | 精品视自拍视频在线观看 | 看一级特黄a大片日本片 | 91亚洲成人| 伊人久久精品午夜 | 美美女高清毛片视频免费观看 | 萝控精品福利视频一区 | 美女张开大腿让男人捅 | 一区二区三区免费 | 久在线播放 | 美国毛片在线 | 精品久久久久中文字幕日本 | 亚洲综合国产一区在线 | 91视频啪啪 | 久久午夜影院 | 97视频在线观看免费 | 欧美精品一区视频 | 欧洲一级大片 | 欧美日韩一区二区视频图片 | 久久毛片网站 | 国产精品aⅴ | a一级毛片免费高清在线 | 特黄特级a级黄毛片免费观看多人 | 成人18免费观看的软件 |