您的位置:首页 > 编程语言 > Go语言

使用Go语句生成数值表

2010-09-23 08:32 405 查看
相对于传统的循环和游标方式生成数据,"GO n"方式更加简洁。

虽然效率低下,但是也不失为一种方法(更高效的可以用row_number+sys.all_columns方式)。

-- 创建测试表
use tempdb
go

CREATE TABLE [dbo].[Tally](

[int] IDENTITY(1,1) NOT NULL,
CONSTRAINT [PK_Tally] PRIMARY KEY CLUSTERED
(
ASC)) ON [PRIMARY]

-- 设置环境
SET NOCOUNT ON
GO
SET IDENTITY_INSERT dbo.Tally ON;
GO
-- 插入首行数据
INSERT dbo.Tally(N) VALUES(IDENT_CURRENT('dbo.Tally'));
GO

-- 重复10000次插入10000行记录,本本上大约花费7s
INSERT dbo.Tally(N) VALUES(IDENT_CURRENT('dbo.Tally')+1);
GO 10000

-- 恢复环境
SET IDENTITY_INSERT dbo.Tally OFF;
GO
SET NOCOUNT OFF
GO

-- 验证结果
SELECT count(1) as TotalNums FROM dbo.Tally;
GO
/*
TotalNums
-----------
10001

*/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: