亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

探討SQL Server存儲(chǔ)過(guò)程

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

A.;;;獲取存儲(chǔ)過(guò)程的ReturnValue值用了這么長(zhǎng)時(shí)間的.NET了,竟然連怎么獲取存儲(chǔ)過(guò)程的返回值都不知道,真是失敗。 在網(wǎng)上搜了一下,就知道怎么用了。 Input 此參數(shù)只用于將信息從應(yīng)用程序傳輸?shù)酱鎯?chǔ)過(guò)程。 InputOutput 此參數(shù)可將信息從應(yīng)用程序傳輸?shù)酱鎯?chǔ)過(guò)程,并將信息從存儲(chǔ)過(guò)程傳輸回應(yīng)用程序。 Output 此參數(shù)只用于將信息從存儲(chǔ)過(guò)程傳輸回應(yīng)用程序。 ReturnValue 此參數(shù)表示存儲(chǔ)過(guò)程的返回值。SQL Server 的存儲(chǔ)過(guò)程參數(shù)列表中不顯示該參數(shù)。它只與存儲(chǔ)過(guò)程的 RETURN 語(yǔ)句中的值相關(guān)聯(lián)。

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

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

B.獲得SQL-server存儲(chǔ)過(guò)程的返回值存儲(chǔ)過(guò)程為:

///<summary> ///c#code,獲得SQL-server存儲(chǔ)過(guò)程的返回值 ///<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); //參數(shù)'ReturnValue',System.Data.ParameterDirection.ReturnValue聲明此參數(shù)為返回值。 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()即可!

存儲(chǔ)過(guò)程為:

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

希望對(duì)剛學(xué)存儲(chǔ)過(guò)程的朋友有點(diǎn)幫助!

用過(guò)SQLHelper的朋友,一定很懷疑SQLHelper怎么不能執(zhí)行帶輸出、返回參數(shù)的存儲(chǔ)過(guò)程呢?請(qǐng)參考 http://blog.joycode.com/ghj/archive/2004/04/12/19015.aspx

此文并沒(méi)有做成相應(yīng)的解決方法,所以這也是寫(xiě)本文的一個(gè)出發(fā)點(diǎn)。原因值需要修改存儲(chǔ)過(guò)程中RETURN @id為SELECT @id,取值采用SqlHelper.ExecuteScalar 方法.其中原理并沒(méi)有違背SqlHelper.ExecuteScalar取第一行一列的值。

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

C.如何在存儲(chǔ)過(guò)程中引用別的存儲(chǔ)過(guò)程返回的表

1.;;;;一般的方法認(rèn)為只有把存儲(chǔ)過(guò)程返回的值,寫(xiě)入一個(gè)結(jié)構(gòu)相同的 輔助表中,如下: create procedure proc1 as begin create table #t(...) --表結(jié)構(gòu)同被調(diào)用存儲(chǔ)過(guò)程返回結(jié)果集的結(jié)構(gòu)

insert #t exec proc2

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

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

主站蜘蛛池模板: 自拍偷拍视频在线观看 | 国产在线91精品天天更新 | 亚洲欧美日本在线观看 | 欧美一级二级毛片视频 | 看一级毛片一区二区三区免费 | 欧美色老头gay | 欧美一级高清片欧美国产欧美 | 免费一级肉体全黄毛片 | 88av视频在线观看 | 久久夜色邦福利网 | 久久免费播放视频 | 波多野结衣中文在线 | 亚洲国产成人精品久久 | 欧美日韩中文字幕在线观看 | 不卡一区二区在线 | 国内精自品线一区91 | 日韩18在线观看 | 日韩亚洲成a人片在线观看 日韩亚洲精品不卡在线 | 91久久香蕉国产线看观看软件 | 成人小视频在线播放 | 操你.com| vr欧美乱强伦xxxxx | 特黄特黄一级高清免费大片 | 久久久欧美综合久久久久 | 成人欧美一区二区三区在线 | 九色91 | 亚洲精品一区二区 | 精品久久久久久久高清 | 久久综合精品不卡一区二区 | 亚洲欧美日韩精品永久在线 | 男女视频在线看 | 国产一级做a爱片久久毛片a | 国产精品成人免费视频 | 国产制服 国产制服一区二区 | 免费在线一区二区三区 | 欧美精品成人一区二区视频一 | 日韩一级精品视频在线观看 | 亚欧美图片自偷自拍另类 | 欧美大片欧美毛片大片 | 精品老司机在线视频香蕉 | 久久久久国产精品免费看 |