SQL快速生成连续整数

Posted 最萌小胡胡

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL快速生成连续整数相关的知识,希望对你有一定的参考价值。

很多时候需要用到连续的id进行数据对比,如判断是否连续等问题。那么,生成连续整数的方式有多种,首先容易想到的是逐步循环,如果想生成2kw条记录,则需要循环2kw次进行插入,那么有没有其他方式呢,效率相对于逐步加一有多少提升呢。

首先创建一张存放记录的表,插入1条记录。

CREATE TABLE dbo.Nums(n INT);
INSERT INTO dbo.Nums VALUES(1);

通常容易想到的是循环插入,每次插入1条,插入20W次,大约耗时10几分钟。。。

按照指数级插入,20W数据只需要插入18次,1s即可完成。

DECLARE @max AS INT, @rc AS INT;
SET @max = 200000;  --数据总数
SET @rc = 1;       --插入次数
WHILE @rc <= @max
BEGIN
  INSERT INTO dbo.Nums SELECT n + @rc FROM dbo.Nums WHERE n+@rc<=@max;
  SET @rc = @rc * 2;
END

具体逻辑理解如下:

第1次插入1条,表数据变为:1 ,2

第2次插入2条,表数据变为:1 , 2 ,3, 4

第3次插入4条,表数据变为:1 ,2 ,3 ,4 ,5 ,6 ,7 ,8

第4次插入8条,表数据变为:1 ,2 ,3 ,4 ,5 ,6 ,7 ,8 ,...... ,16

......

第17次插入65536行,表数据变为:1 ,2 ,3 ,4 ,5 ,6 ,7 ,8 ,...... ,131072

第18次插入剩余的68928行。

 

以上是关于SQL快速生成连续整数的主要内容,如果未能解决你的问题,请参考以下文章

前端开发工具vscode如何快速生成代码片段

前端开发工具vscode如何快速生成代码片段

VS Code配置snippets代码片段快速生成html模板,提高前端编写效率

sql [SQL查询片段]用于在命令行或通过R和其他工具使用SQL的快速代码段#tags:sql,R,text processing,命令li

非连续重复的整数数组

vscode之快速生成vue模板