当前位置:首页 > 芯闻号 > 充电吧
[导读]SQL Server 2008中SQL应用系列--目录索引经常我们会遇到需要一次往数据表中插入多行数据。此时,最简单的莫过于调用存储过程。比如目标表如下:USE testDb2 GO IF NOT

SQL Server 2008中SQL应用系列--目录索引

经常我们会遇到需要一次往数据表中插入多行数据。此时,最简单的莫过于调用存储过程。

比如目标表如下:

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

调用存储过程插入一个行集

/*************一次插入一个行集******************/
/********* 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

如果需要多行,则循环调用存储过程即可。这样做的坏处是显而易见的。于是有了改进方案:

/*************一次插入五个行集******************/
/********* 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

这样,一次可以插入五条数据,当然十条也可以。但明显也有不足,首先,如果刚好要插入3条数据,那么应该避免null值和允许插入等异常。

幸运的是,SQL Server 2008提供了新的表值参数,可以一次性传入并处理多个行集。

示例如下:

/*************一次插入N个行集******************/
/********* 3w@live.cn 邀月***************/

----首先,我们定义一个表值参数类型,其实就是一个表变量
Create type dbo.tp_Demo_MultiRowsInsert as Table
(
[PName] [Nvarchar](20) NOT NULL,
[GName] [Nvarchar](20) NOT NULL
)
GO

----下面我们用这个表变量做参数,通过存储过程调用它
CREATE Procedure dbo.CPP_InsertMultiRows
(@ManyRows as tp_Demo_MultiRowsInsert readonly
)
as
INSERT [dbo].[tb_Demo_MultiRowsInsert]
SELECT PName,GName from @ManyRows

GO

----程序中构造多个行集
DECLARE @tmpRows as tp_Demo_MultiRowsInsert

----插入多个数据到参数表中
INSERT @tmpRows(PName,GName) values('胡一刀','国土资源部')
INSERT @tmpRows(PName,GName) values('胡青牛','医药局')
INSERT @tmpRows(PName,GName) values('令狐冲','文广中心')

----传递参数到存储过程,完成一次多行集插入
EXEC dbo.CPP_InsertMultiRows @tmpRows

 注意:这种一次转入多个参数的模式与SQL Servrer 2008新增的Values((group1),(group2),...,(groupn))的方式很类似,后者的应用可以看这里:

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

小结:SQL Server 2008 新增参数类型-表值参数。使用用户定义的表类型来声明,借助它,可以不必创建临时表或许多参数,即可向存储过程发送多行数据。对于某些繁忙的系统,这减少了应用程序和数据库服务器之间的交互,从而减少了占用的带宽,数据库端的事务处理更高效。



本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭