加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL Server中数据行批量插入脚本的存储实现

发布时间:2020-12-12 09:17:12 所属栏目:MsSql教程 来源:网络整理
导读:无意中看到朋友写的一篇文章“”。我仔细看文中的两个存储代码,自我感觉两个都不太满意,都是生成的单行模式的插入,数据行稍微大些性能会受影响的。所在公司本来就存在第二个版本的类似实现,但是是基于多行模式的,还是需要手工添加UNAION ALL来满足多行

无意中看到朋友写的一篇文章“”。我仔细看文中的两个存储代码,自我感觉两个都不太满意,都是生成的单行模式的插入,数据行稍微大些性能会受影响的。所在公司本来就存在第二个版本的类似实现,但是是基于多行模式的,还是需要手工添加UNAION ALL来满足多行模式的插入。看到这篇博文和基于公司数据行批量脚本的存储的缺点,这次改写和增强该存储的功能。

本存储运行于SQL Server 2005或以上版本,T-SQL代码如下:

-- -- 此处不能使用GOTO WhereCondition;,因为之后的代码不会被执行
-- IF @chvnWhere > ''
-- BEGIN
-- SET @chvnTSQL = @chvnTSQL + ' WHERE ' + @chvnWhere;
-- END
-- -- 处理多行模式,需要使用ROW_NUMBER窗口函数
-- SET @chvnTSQL = N'SELECT CASE WHEN T.rownum = THEN REPLICATE(N'' '',LEN(N''UNION ALL '') + ) + T.RowData ELSE N''UNION ALL '' + T.RowData END' +
-- N' FROM (' + @chvnTSQL + N') AS T';
-- SET @chvnTSQL = N'SELECT '+ @chvnInsertIntoBoday + N';' +
-- @chvnTSQL;
-- GOTO MultiRow;
-- END
-- ELSE IF @bitIsSingleRow = /当行模式/
-- BEGIN
-- SET @chvnTSQL = N'SELECT ' + @chvnInsertIntoBoday +
-- N' + ''VALUES('' + ' + @chvnColumnValues + ' + '');'' FROM ' + @chvnSchemaTableName;
-- GOTO WhereCondition;
-- END
-- -- where查询条件
-- WhereCondition:
-- IF @chvnWhere > ''
-- BEGIN
-- SET @chvnTSQL = @chvnTSQL + ' WHERE ' + @chvnWhere;
-- END

-- MultiRow:/多行模式GOTO的Label空标记/
--END
-- 方式二、存在部分代码的冗余
BEGIN
IF @bitIsSingleRow = /多行模式/
BEGIN
SET @chvnTSQL = N'SELECT ''SELECT '' + ' + @chvnColumnValues + ' AS RowData,ROW_NUMBER() OVER(ORDER BY (SELECT NULL)) AS RowNum FROM ' + @chvnSchemaTableName
IF @chvnWhere > ''
BEGIN
SET @chvnTSQL = @chvnTSQL + ' WHERE ' + @chvnWhere;
END
-- 多行模式特殊代码,需要使用ROW_NUMBER窗口函数
SET @chvnTSQL = N'SELECT CASE WHEN T.rownum = THEN REPLICATE(N'' '',LEN(N''UNION ALL '') + ) + T.RowData ELSE N''UNION ALL '' + T.RowData END' +
N' FROM (' + @chvnTSQL + N') AS T';
SET @chvnTSQL = N'SELECT '+ @chvnInsertIntoBoday + N';' +
@chvnTSQL;
END
ELSE IF @bitIsSingleRow = /单行模式/
BEGIN
SET @chvnTSQL = N'SELECT ' + @chvnInsertIntoBoday +
N' + ''VALUES('' + ' + @chvnColumnValues + ' + '');'' FROM ' + @chvnSchemaTableName;
IF @chvnWhere > ''
BEGIN
SET @chvnTSQL = @chvnTSQL + ' WHERE ' + @chvnWhere;
END
END
END
PRINT @chvnTSQL;
EXEC(@chvnTSQL);
END
GO

为了测试以上存储的效果,下面准备一个有数据的数据表,T-SQL代码如下:

先测试单行模式的效果,相应的T-SQL代码如下:

EXEC dbo.usp_GetInsertSQL
@chvnTable = N'UserLoginInfo',-- nvarchar()
@chvnWhere = N'',-- nvarchar()
@bitIsSingleRow = ; -- bit
GO

执行后的查询结果如下:

再测试多行模式的效果,相应的T-SQL代码如下:

执行后的查询效果如下:

以上内容是小编给大家分享的SQL Server中数据行批量插入脚本的存储实现,希望大家喜欢。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读