www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 芯聞號(hào) > 充電吧
[導(dǎo)讀]SQL Server 2008中SQL應(yīng)用系列--目錄索引經(jīng)常我們會(huì)遇到需要一次往數(shù)據(jù)表中插入多行數(shù)據(jù)。此時(shí),最簡(jiǎn)單的莫過(guò)于調(diào)用存儲(chǔ)過(guò)程。比如目標(biāo)表如下:USE?testDb2 GO IF?NOT

SQL Server 2008中SQL應(yīng)用系列--目錄索引

經(jīng)常我們會(huì)遇到需要一次往數(shù)據(jù)表中插入多行數(shù)據(jù)。此時(shí),最簡(jiǎn)單的莫過(guò)于調(diào)用存儲(chǔ)過(guò)程。

比如目標(biāo)表如下:

USE?testDb2
GO

IF?NOT?OBJECT_ID('tb_Demo_MultiRowsInsert')?IS?NULL
DROP?TABLE?[tb_Demo_MultiRowsInsert]

/******?Object:?Table?[dbo].[tb_Demo_MultiRowsInsert]?Script?Date:?2012/4/6?12:19:21?******/

CREATE?TABLE?[dbo].[tb_Demo_MultiRowsInsert](
[TeamID]?int?not?null?primary?key?identity(101,1),
[PName]?[Nvarchar](20)?NOT?NULL,
[GName]?[Nvarchar](20)?NOT?NULL
)

GO

調(diào)用存儲(chǔ)過(guò)程插入一個(gè)行集

/*************一次插入一個(gè)行集******************/
/*********?3w@live.cn?邀月***************/
Create?Procedure?CPP_InsertOneRows
(@PName?Nvarchar(20)='',
@GName?Nvarchar(20)=''
)
as
INSERT?[dbo].[tb_Demo_MultiRowsInsert]?(PName,GName)
VALUES(@PName,@GName)
GO

如果需要多行,則循環(huán)調(diào)用存儲(chǔ)過(guò)程即可。這樣做的壞處是顯而易見(jiàn)的。于是有了改進(jìn)方案:

/*************一次插入五個(gè)行集******************/
/*********?3w@live.cn?邀月***************/
Create?Procedure?CPP_InsertFiveRows
(
@PName1?Nvarchar(20)='',
@GName1?Nvarchar(20)='',
@PName2?Nvarchar(20)='',
@GName2?Nvarchar(20)='',
@PName3?Nvarchar(20)='',
@GName3?Nvarchar(20)='',
@PName4?Nvarchar(20)='',
@GName4?Nvarchar(20)='',
@PName5?Nvarchar(20)='',
@GName5?Nvarchar(20)=''
)
as

INSERT?[dbo].[tb_Demo_MultiRowsInsert]?(PName,GName)
VALUES(@PName1,@GName1)

INSERT?[dbo].[tb_Demo_MultiRowsInsert]?(PName,GName)
VALUES(@PName2,@GName2)

INSERT?[dbo].[tb_Demo_MultiRowsInsert]?(PName,GName)
VALUES(@PName3,@GName3)

INSERT?[dbo].[tb_Demo_MultiRowsInsert]?(PName,GName)
VALUES(@PName4,@GName4)

INSERT?[dbo].[tb_Demo_MultiRowsInsert]?(PName,GName)
VALUES(@PName5,@GName5)
GO

這樣,一次可以插入五條數(shù)據(jù),當(dāng)然十條也可以。但明顯也有不足,首先,如果剛好要插入3條數(shù)據(jù),那么應(yīng)該避免null值和允許插入等異常。

幸運(yùn)的是,SQL Server 2008提供了新的表值參數(shù),可以一次性傳入并處理多個(gè)行集。

示例如下:

/*************一次插入N個(gè)行集******************/
/*********?3w@live.cn?邀月***************/

----首先,我們定義一個(gè)表值參數(shù)類(lèi)型,其實(shí)就是一個(gè)表變量
Create?type?dbo.tp_Demo_MultiRowsInsert?as?Table
(
[PName]?[Nvarchar](20)?NOT?NULL,
[GName]?[Nvarchar](20)?NOT?NULL
)
GO

----下面我們用這個(gè)表變量做參數(shù),通過(guò)存儲(chǔ)過(guò)程調(diào)用它
CREATE?Procedure?dbo.CPP_InsertMultiRows
(@ManyRows?as?tp_Demo_MultiRowsInsert?readonly
)
as
INSERT?[dbo].[tb_Demo_MultiRowsInsert]
SELECT?PName,GName?from?@ManyRows

GO

----程序中構(gòu)造多個(gè)行集
DECLARE?@tmpRows?as?tp_Demo_MultiRowsInsert

----插入多個(gè)數(shù)據(jù)到參數(shù)表中
INSERT?@tmpRows(PName,GName)?values('胡一刀','國(guó)土資源部')
INSERT?@tmpRows(PName,GName)?values('胡青牛','醫(yī)藥局')
INSERT?@tmpRows(PName,GName)?values('令狐沖','文廣中心')

----傳遞參數(shù)到存儲(chǔ)過(guò)程,完成一次多行集插入
EXEC?dbo.CPP_InsertMultiRows?@tmpRows

?注意:這種一次轉(zhuǎn)入多個(gè)參數(shù)的模式與SQL Servrer 2008新增的Values((group1),(group2),...,(groupn))的方式很類(lèi)似,后者的應(yīng)用可以看這里:

http://www.cnblogs.com/downmoon/archive/2010/10/12/1849176.html

小結(jié):SQL Server 2008 新增參數(shù)類(lèi)型-表值參數(shù)。使用用戶(hù)定義的表類(lèi)型來(lái)聲明,借助它,可以不必創(chuàng)建臨時(shí)表或許多參數(shù),即可向存儲(chǔ)過(guò)程發(fā)送多行數(shù)據(jù)。對(duì)于某些繁忙的系統(tǒng),這減少了應(yīng)用程序和數(shù)據(jù)庫(kù)服務(wù)器之間的交互,從而減少了占用的帶寬,數(shù)據(jù)庫(kù)端的事務(wù)處理更高效。



本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶(hù)希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話(huà)語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉