admin 管理员组

文章数量: 1086019


2024年3月13日发(作者:ubuntu镜像文件iso下载官网)

分享高性能批量插入和批量删除sql语句写法

一,技术水平总能在扯皮和吹毛求疵中得到提高。如果从来不“求疵”,可能就不会知

道if(str != )不如if(str != )高效、批量插入和删除的sql语句是要那样写才执

行最快、接口和抽象类的区别不仅是语言层面、原来权限管理是要这样设计的、某个类那样

设计职责才更单一更易于扩展……

本来前两篇文章是学习cnblogs编辑控件用的,看到跟贴的朋友询问批量插入和批量

删除的问题,决定整理成文和大家分享。

我们这里讨论的只是普通sql语句如何写更高效,不考虑特殊的用文件中转等导入方

式,毕竟在代码中调用sql语句或存储过程才更方便。

批量删除很简单,大家可能都用过:

delete from testtable where id in (1, 3, 54, 68) --sql2005下运行通过 当用户在

界面上不连续的选择多项进行删除时,该语句比循环调用多次删除或多条delete语句中间

加分号一次调用等方法都高效的多。

本文重点讲述的是批量插入的写法:

sql写法:

insert into testtable select 1, abc union select 2, bcd union select 3,

cde--testtable表没有主键,id不是主键

oracle写法:

insert into testtable select 1, abc from daul union select 2, bcd from daul

--testtable表没有主键,id不是主键

曾经测试过,这种写法插入1000条数据比循环调用1000次insert或1000条insert

语句简单叠加一次调用要高效得多,大概快20多倍(调试状态不是太准)。其实很简单,

就用了个union(union all 也可以),但当时得出测试结果时还是很惊喜的。

要得出这个结果需要两个条件:

1、表不能有主键或者主键是数据库默认的(sql用自动递增列,oracle用序列)

1

以上两条任意一条不满足,效率的提高都不明显。

另外,sql语句的最大长度有限制,组合几千条数据写成一条insert语句,可能会超过

上限,所以如果有5000条数据,可以一次insert 1000条,分5次写完(不一定一次1000

条最合适,有兴趣的朋友可以研究)。

声明:看了几位朋友的评论后发现自己没有叙述清楚

上面的两个条件并不是说这样做就好,而是说当应用场景满足这两个条件时才适合用

union的写法


本文标签: 批量 语句 删除 主键 插入