如何在SQLserver中利用循环语句插入大量的数据?

如何在SQLserver中利用循环语句插入大量的数据?,第1张

这个在sqlserver里面不好做,要用到sql语言中的变量并且sql语音没有for不过有while,不过一般数据都不会这样批量输入,毕竟不是每条数据都之间都存在内在的联系。如果你真的想用for语句进行录入的话,你就用visual studio连接你的数据库用c#代码来完成这个活。

DECLARE @id INT,@username NVARCHAR(50),@Pwd NVARCHAR(50)

SET @id=0

SET @username ='kk'

SET @Pwd='12345'

WHILE @i<10000      --10000为你要执行插入的次数

BEGIN

INSERT INTO xx ( id, username,Pwd )  --xx为表名

VALUES  ( @id, @username,@Pwd  )

SET @i=@i+1

END

declare @i int

set @i = 0

while @i <100

begin

print @i

set @i = @i + 1

end

-- 定义循环变量

declare @loopIndex int set @loopIndex = 0

--定义循环次数

declare @count int set @count=1

-- 取得循环次数

select @count=count(1) from sys_user

-- 开始循环

while @loopIndex <= @count

begin

  -- 定义接收参数

  declare @USER_NAME nvarchar(50)

-- 取得循环的数据

SELECT @USER_NAME = hh.USER_NAME

FROM (SELECT ROW_NUMBER() OVER (ORDER BY USER_NAME) 'rowindex',USER_NAME FROM sys_user)hh 

WHERE hh.rowindex = @loopIndex

-- 进行相关业务逻辑 例如输出结果 

print @USER_NAME

-- 循环自动加一

set @loopIndex = @loopIndex + 1

end

begin

  -- 定义错误返回信息

  declare @error int 

-- 定义接收参数

  declare @User_Name varchar(50)

  declare @Address varchar(50)

  set @error=0

  --定义游标

  declare demo_cursor cursor

  for (select User_Name,Address from sys_user)

  --打开游标--

  open demo_cursor

  --开始循环游标变量--

  fetch next from demo_cursor into @User_Name,@Address

  while @@FETCH_STATUS = 0  --返回被 FETCH语句执行的最后游标的状态--

    begin       

      print @User_Name+'____'+@Address

      set @error= @error + @@ERROR  --记录每次运行sql后是否正确,0正确

      fetch next from demo_cursor into @User_Name,@Address  --转到下一个游标,没有会死循环

    end  

  close demo_cursor --关闭游标

  deallocate demo_cursor  --释放游标

end

更多内容请访问: https://mxdqh.top/


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11743980.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存