mssql

推荐列表 站点导航

当前位置:首页 > 数据库 > mssql >

sql server中批量插入与更新两种解决方案分享(存储过程)

来源:网络整理  作者:网络  发布时间:2020-12-08 22:34
对于sql 来说操作集合类型(一行一行)是比较麻烦的一件事,而一般业务逻辑复杂的系统或项目都会涉及到集合遍历的...
DECLARE @Data NVARCHAR(max)
DEALLOCATE data_cursor


*/
FETCH NEXT FROM data_cursor INTO @dataItem
DECLARE data_cursor CURSOR FOR (SELECT * FROM split(@Data,';'))
CLOSE data_cursor
DECLARE @dataItem NVARCHAR(100)
WHILE @@FETCH_STATUS=0


BEGIN
DECLARE @Name NVARCHAR(50)
*/
FETCH NEXT FROM dataItem_cursor INTO @Id

BEGIN
DECLARE @Id INT
FETCH NEXT FROM dataItem_cursor INTO @Name


DECLARE @Temp TABLE
DECLARE @Name NVARCHAR(50)
INSERT INTO @Temp SELECT (SELECT * FROM split(@Data,';'))
SET @Results=@Results+@Name+','

CLOSE dataItem_cursor
SET @Data='1,tanw,2,keenboy' --Id,Name
/*

SELECT TOP 1 @Id=Id,@Name=Name from @Temp
DEALLOCATE dataItem_cursor

复制代码 代码如下:


在这里做逻辑处理,插入或更新操作 ...
DECLARE @Results NVARCHAR(MAX) SET @Results=''

复制代码 代码如下:

DECLARE dataItem_cursor CURSOR FOR (SELECT * FROM split(@dataItem,','))

OPEN dataItem_cursor
在这里做逻辑处理,插入或更新操作 ...
)
WHILE EXISTS(SELECT * FROM @Temp)
(
OPEN data_cursor

END
/*
2.While方式
SELECT @Results
DELETE FROM @Temp where [id] = @Id
DECLARE @Id INT
SET @Data='tanw,keenboy' --Id,Name
END
DECLARE @Data NVARCHAR(max)
Id INT IDENTITY(1,1),
Name NVARCHAR(50)

相关热词: 解决

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/mssql/1576.shtml

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

sql server中批量插入与更新两种解决方案分享(存储过程)

2020-12-08 编辑:网络

DECLARE @Data NVARCHAR(max)
DEALLOCATE data_cursor


*/
FETCH NEXT FROM data_cursor INTO @dataItem
DECLARE data_cursor CURSOR FOR (SELECT * FROM split(@Data,';'))
CLOSE data_cursor
DECLARE @dataItem NVARCHAR(100)
WHILE @@FETCH_STATUS=0


BEGIN
DECLARE @Name NVARCHAR(50)
*/
FETCH NEXT FROM dataItem_cursor INTO @Id

BEGIN
DECLARE @Id INT
FETCH NEXT FROM dataItem_cursor INTO @Name


DECLARE @Temp TABLE
DECLARE @Name NVARCHAR(50)
INSERT INTO @Temp SELECT (SELECT * FROM split(@Data,';'))
SET @Results=@Results+@Name+','

CLOSE dataItem_cursor
SET @Data='1,tanw,2,keenboy' --Id,Name
/*

SELECT TOP 1 @Id=Id,@Name=Name from @Temp
DEALLOCATE dataItem_cursor

复制代码 代码如下:


在这里做逻辑处理,插入或更新操作 ...
DECLARE @Results NVARCHAR(MAX) SET @Results=''

复制代码 代码如下:

DECLARE dataItem_cursor CURSOR FOR (SELECT * FROM split(@dataItem,','))

OPEN dataItem_cursor
在这里做逻辑处理,插入或更新操作 ...
)
WHILE EXISTS(SELECT * FROM @Temp)
(
OPEN data_cursor

END
/*
2.While方式
SELECT @Results
DELETE FROM @Temp where [id] = @Id
DECLARE @Id INT
SET @Data='tanw,keenboy' --Id,Name
END
DECLARE @Data NVARCHAR(max)
Id INT IDENTITY(1,1),
Name NVARCHAR(50)

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/mssql/1576.shtml

相关文章

风云图片

推荐阅读

返回mssql频道首页