SQL SERVER存储过程批量插入数据库表数据

SQL SERVER存储过程批量插入数据库表数据

这是个简单的例子,向岗位表中插入数据。要求编号名称全部是以GSPOS_为前缀的,如POS_1,一直到POS_1000,备注里内容如批量加的GSPOS_1,批量加的GSPOS_2......

Declare @td int
DECLARE @base VARCHAR(30)
DECLARE @id VARCHAR(30)
SET @base='gspos_'
SET @td=1


while @td< 2001
 begin
set @id=@base+CONVERT(VARCHAR,@td)
insert intogspposition(ID,CODE,NAME,TYPE,ORGID,Sysinit,description,Creator,Createdtime)
 values ( @id,@id,@id, 1, '0102',0,'批量添加'+@id,'9999','2009-7-2014:28:03');
set @td=@td+1
end
go


以下为往用户表中插入数据。

Declare @td int
DECLARE @base VARCHAR(30)
DECLARE @id VARCHAR(30)
SET @base='gs_'
SET @td=1


while @td< 2001
 begin
set @id=@base+CONVERT(VARCHAR,@td)
insert intogspuser(ID,CODE,NAME,PASSWORD,TYPE,STATE,DEFORGID,DAYLIMIT,TIMELIMIT,Creatorid,Createddate,
passvalidspan,profile,alterpassflag,defposid,authcontent,sysinit)
 values ( @id,@id,@id,'96niR3fsIyEsVNejULxb6lR3/bs=',1,1,'0102','1111111','111111111111111111111111','6e35ff7d-5e7b-427e-8f51-d898a4a630e1','2009-10-2811:06:21.017','0','AAEAAAD/AQAAAAAAAAAEAQAAAOIBU3lzdGVtLkNvbGxlY3Rpb25zLkdlbmVyaWMuRGljdGlvbmFyeWAyW1tTeXN0ZW0uT2JqZWN0LCBtc2NvcmxpYiwgVmVyc2lvbj0yLjAuMC4wLCBDdWx0dXJlPW5ldXRyYWwsIFB1YmxpY0tleVRva2VuPWI3N2E1YzU2MTkzNGUwODldLFtTeXN0ZW0uT2JqZWN0LCBtc2NvcmxpYiwgVmVyc2lvbj0y',0, '18821f6c-21fb-457f-a57b-c0f7ecec0196','1,0,0',0);
set @td=@td+1
end
go

 


下面是详细介绍复杂的例子。


在做数据库系统开发时,特别是需要对数据库操作进行性能测试及优化时,我们就需要在数据库测试表中插入大量数据以便测试。对于这些数据的插入,这里通过实例展示如何通过存储过程进行实现。
 
     数据库表(userInfo)结构如下:
 


CREATE TABLE [dbo].[userInfo] (
 [userID] [int] IDENTITY (1, 1) NOT NULL ,
 [roleType] [int] NULL ,
 [groupID] [int] NULL ,
 [userCode] [varchar] (50) COLLATEChinese_PRC_CI_AS NULL ,
 [userName] [varchar] (50) COLLATEChinese_PRC_CI_AS NULL ,
 [text1] [varchar] (50) COLLATE Chinese_PRC_CI_ASNULL ,
 [text2] [varchar] (50) COLLATE Chinese_PRC_CI_ASNULL ,
 [text3] [varchar] (50) COLLATE Chinese_PRC_CI_ASNULL
) ON [PRIMARY]
GO
 
   存储过程如下(这里是批量插入99000条数据,roleType,groupID两个字段为随机生成的0-5之间的数):
 


CREATE PROCEDURE add_UserInfo
AS
DECLARE @userCode VARCHAR(30)
DECLARE @userName VARCHAR(30)

DECLARE @userCode_base VARCHAR(30)
DECLARE @count INTEGER
DECLARE @index INTEGER
DECLARE @rand1 INTEGER
DECLARE @rand2 INTEGER
SET @userCode_base='qs_'
SET @userName='userName'
SET @count=100000
SET @index=10000

WHILE @index<@count
BEGIN
 SET@userCode=@userCode_base+CONVERT(VARCHAR,@index)
 SET @rand1=convert(int,rand()*5)
 SET @rand2=convert(int,rand()*5)
 INSERT INTO userInfo(userCode,roleType,groupID,userName,text1,text2,text3)
 VALUES (@userCode,@rand1,@rand2,@userName,'aokeikaol jof','','aokei kaol jof')
 
 SET @index=@index+1
END
GO

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值