批量性能(CTE、事务、NoCount等)

步骤一、创建两个表

CREATE TABLE [dbo].[Test_Old](
    [ID] [nvarchar](50) NULL
)
CREATE TABLE [dbo].[Test_New](
    [ID] [nvarchar](50) NULL
)

步骤二、使用事务、设置NoCount,先创建基础数据:向表Test_Old中插入10万条数据

----清除干扰查询  
DBCC DROPCLEANBUFFERS  
DBCC FREEPROCCACHE  
--开启IO和时间统计
SET STATISTICS IO ON;  
SET STATISTICS TIME ON;  
GO 
--*****************************************************正文
--1.循环插入
declare @i int,@d Datetime   
SET @d=getdate();  
SET @i = 1
--1.1 设置 NoCount 
SET NoCount On
--1.2 开启事务
BEGIN TRANSACTION 
while @i < 100000
begin
set @i = @i + 1
END
--关闭IO和时间统计*****************************************************
SET STATISTICS IO OFF ;  
SET STATISTICS TIME OFF;  
GO  

步骤三、使用CTE公用表表达式,从Test_Old向Test_New中插入数据(性能极高)

WITH B AS 
(
    SELECT * FROM Test_Old
)
Insert into Test_New(ID) select ID from B
  1. The end,thank you!
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 步骤一、创建两个表 步骤二、使用事务、设置NoCount,先创建基础数据:向表Test_Old中插入10万条数据 ...
    Asa_Guo阅读 1,769评论 0 0
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,183评论 19 139
  • 50个常用的sql语句Student(S#,Sname,Sage,Ssex) 学生表Course(C#,Cname...
    哈哈海阅读 5,034评论 0 7
  • 2017年5月4日 星期四 多云 今天我的两个“小可爱”可把我气的不轻。 上午第三节我去检查业务,布置让孩子们做《...
    红叶与蓝鲸的美好相遇阅读 2,206评论 1 0
  • 1. 我跟我妈说我要买个6S,最好是128个G的,不然不够用,我妈顿时很诧异地说:我的手机才4G的,你居然要128...
    徐徐66阅读 2,732评论 0 0

友情链接更多精彩内容