sql server中批量插入与更新两种解决方案分享(存储过程)
对于sql 来说操作集合类型(一行一行)是比较麻烦的一件事,而一般业务逻辑复杂的系统或项目都会涉及到集合遍历的问题,通常一些人就想到用游标,这里我列出了两种方案,供大家参考
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
/*
在这里做逻辑处理,插入或更新操作 ...
www.jb51.net
*/
END
CLOSE data_cursor
DEALLOCATE data_cursor
2.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+','
www.jb51.net
/*
在这里做逻辑处理,插入或更新操作 ...
*/
END
SELECT @Results
如果是简单单表批量插入操作的,上面方法大可不必要
作者 keenboy

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

标题:Oracle存储过程实现批量更新的步骤与注意事项在Oracle数据库中,存储过程是一组为了提高数据库性能、重用代码、增强安全性的SQL语句集合,通过存储过程可以实现批量更新数据的操作。本文将介绍如何使用Oracle存储过程实现批量更新,并提供具体的代码示例。步骤一:创建存储过程首先,我们需要创建一个存储过程,用来实现批量更新的操作。以下是创建存储过程的

Excel数据导入Mysql常见问题汇总:如何解决导入数据时遇到的大批量插入问题?导入Excel数据到MySQL是日常开发中经常遇到的任务之一。对于少量数据的导入,可以使用数据库客户端工具或者命令行进行插入操作。但当面对大批量数据导入时,简单的单条插入操作无疑会导致严重的性能问题。本文将介绍如何解决这个问题,并给出相应的代码示例。问题描述:在实际使用过程中,

Oracle存储过程批量更新在数据处理中的应用案例在实际的数据处理中,我们经常需要对数据库中的大量数据进行更新操作。Oracle数据库提供了存储过程的功能,可以有效地处理这些大批量数据更新的操作,提高数据处理效率和性能。在本文中,我们将介绍Oracle存储过程批量更新的应用案例,并且提供具体的代码示例,帮助读者更好地理解和运用这一功能。案例背景假设我们有一个

Vue和Excel的默契合作:如何实现数据的批量更新和导入引言:随着信息技术的快速发展,Excel表格作为一种流行的数据管理工具,被广泛应用于各个行业和领域。与此同时,Vue作为一种灵活、高效的前端开发框架,也广受欢迎。本文将介绍如何通过Vue和Excel的默契合作,实现数据的批量更新和导入。为了帮助读者更好地理解,我们将给出代码示例。实现数据批量更新:在V

Vue和Excel的高效组合:如何实现数据的批量更新和导入随着Web应用程序的不断发展和数据量的不断增加,我们经常会遇到需要批量更新和导入数据的情况。而Excel作为一种广泛使用的电子表格工具,具有强大的数据处理和导入导出功能,成为我们处理大量数据的首选工具之一。本文将介绍如何使用Vue和Excel实现数据的批量更新和导入,以提高数据处理的效率。首先,我们需

在本文中,我们将看到如何在Hibernate中执行批量插入/更新。每当我们执行一条sql语句时,我们都是通过对数据库进行网络调用来完成的。现在,如果我们必须向数据库表中插入10个条目,那么我们必须进行10次网络调用。相反,我们可以通过使用批处理来优化网络调用。批处理允许我们在单个网络调用中执行一组SQL语句。为了理解和实施这一点,让我们定义我们的实体−@EntitypublicclassParent{@Id@GeneratedValue(strategy=GenerationType.AUTO)

Java开发中如何解决数据库更新性能问题摘要:随着数据量的增加和业务的变化,数据库更新的性能问题成为了Java开发中一大挑战。本文将介绍一些常见的解决数据库更新性能问题的方法和技巧。关键词:Java开发,数据库,更新性能问题,解决方法引言:在大多数Java应用程序中,数据库扮演着重要的角色。数据库的性能直接影响了应用程序的响应速度和稳定性。而在实际开发中,数

MySQL是一种广泛使用的关系型数据库管理系统,其提供了许多有效的数据操作方法。当需要更新大量数据时,可以使用批次更新方法来提高效率。本文将介绍MySQL中的批次更新方法。一、什么是批次更新?批次更新是指通过一条SQL语句来更新多个数据行。相比于每次更新一行的方法,批次更新能够有效降低数据库的负载和网络传输时间,提升数据操作的效率和速度。二、批次更新的实现方
