栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 数据库 > MySQL > MsSql

关于sql server批量插入和更新的两种解决方案

MsSql 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

关于sql server批量插入和更新的两种解决方案

复制代码 代码如下:
.游标方式 1 DECLARE @Data NVARCHAr(max)
 SET @Data='1,tanw;2,keenboy'   --Id,Name

 DECLARE @dataItem NVARCHAr(100)
 DECLARE data_cursor CURSOR FOR (SELECt * FROM split(@Data,';'))
 OPEN data_cursor
 FETCH NEXT FROM data_cursor INTO @dataItem   
 WHILE @@FETCH_STATUS=0
 BEGIN
 DECLARE @Id INT
 DECLARE @Name NVARCHAr(50)

 DECLARE dataItem_cursor CURSOR FOR (SELECt * FROM split(@dataItem,','))
 OPEN dataItem_cursor   
 FETCH NEXT FROM dataItem_cursor INTO @Id
 FETCH NEXT FROM dataItem_cursor INTO @Name
 CLOSE dataItem_cursor
 DEALLOCATE dataItem_cursor

 
 END

 CLOSE data_cursor
 DEALLOCATE data_cursor

复制代码 代码如下:
.While方式
 DECLARE @Data NVARCHAr(max)
 SET @Data='tanw,keenboy'   --Id,Name

 DECLARE @Temp TABLE
 (
    Id INT IDENTITY(1,1),
    Name  NVARCHAr(50)
 )
 DECLARE @Id INT
 DECLARE @Name NVARCHAr(50)
 DECLARE @Results NVARCHAr(MAX) SET @Results=''
 INSERT INTO @Temp SELECt (SELECT * FROM split(@Data,';'))

 WHILE EXISTS(SELECt * FROM @Temp)
 BEGIN
     SELECt TOP 1 @Id=Id,@Name=Name from @Temp
     DELETe FROM @Temp where [id] = @Id
     SET @Results=@Results+@Name+','

    
 END
 SELECT @Results

如果是简单单表批量插入操作的,上面方法大可不必要

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/169872.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号