SQL Server插入或者批量导入大量数据的性能表现
我经常看到客户测试SQL Server 的插入(INSERT)或者批量导入大量数据的性能表现。其中有测试大量INSERT的TSQL脚本如下: use myDB go create table t1 ( id int primary key not null identity ( 1 , 1 ), name varchar ( 200 ), memo char ( 500 )); go trun
我经常看到客户测试SQL Server 的插入(INSERT)或者批量导入大量数据的性能表现。其中有测试大量INSERT的TSQL脚本如下:
use myDB
go
createtable t1(id intprimarykeynotnullidentity (1,1),name varchar(200),memo char(500));
go
truncatetable t1
go
declare @i int
set @i=0
declare @beginTime datetime,@endTime datetime
set @beginTime=GETDATE()
while(@i200000)
begin
insertinto t1(name,memo)values('test'+str(RAND()*100000000),'memo'+str(RAND()*100000000))
set @i=@i+1
end
set @endTime=GETDATE()
select @endTime-@beginTime
上面这个脚本测试插入200000行数据需要的时间。这个脚本有问题么?
语法没有问题,但是写法却不够优化。如果你使用performance monitor
来观察,就会发现在数据插入期间log flushes/sec的次数非常高。在我的机器上达到5000。Log flushes发生一次,意味着SQL server 需要写入事务日志(transaction log)一次。每秒5000次的日志写动作导致磁盘大量的写操作。正是这个磁盘写操作影响了上面的batch的性能。我上面脚本在我的机器上使用了大概40秒左右的时间。
如何改进这个脚本的性能呢?如何减少log flushes/sec从而减少磁盘的写操作? 答案是使用Batch Size如下面脚本所示。
truncatetable t1
go
declare @i int
set @i=0
declare @beginTime datetime,@endTime datetime
set @beginTime=GETDATE()
declare @batchSize int
set @batchSize=1000
while(@i00000)
begin
if (@i%@batchSize=0)
begin
if (@@TRANCOUNT>0)COMMITTRAN
BEGINTRAN
end
insertinto t1(name,memo)values('test'+str(RAND()*100000000),'memo'+str(RAND()*100000000))
set @i=@i+1
end
if (@@TRANCOUNT>0)COMMITTRAN
set @endTime=GETDATE()
select @endTime-@beginTime
黄色高亮是我改进的地方。我在同样的机器上跑了一下,奇迹发生了,它只使用了7秒多一点。快了5倍多!如果在看下performance

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











SQL에서의 MINUS 사용 및 특정 코드 예 SQL에서 MINUS는 두 결과 집합 간의 차이 연산을 수행하는 데 사용되는 연산자입니다. 두 번째 결과 집합에서와 마찬가지로 첫 번째 결과 집합에서도 동일한 행을 삭제하는 데 사용됩니다. MINUS 연산자가 반환한 결과 집합에는 첫 번째 결과 집합에만 존재하는 행이 포함됩니다. 다음은 특정 코드 예제를 사용하여 MINUS의 사용법을 보여줍니다. "table1"과 "table2"라는 두 개의 테이블이 있고 해당 구조는 다음과 같다고 가정합니다. 테이블 이름: table1 필드

해결 방법예, add() 메서드를 사용하여 쉽게 Null 값을 삽입할 수 있습니다. List 구현이 Null을 지원하지 않는 경우에는NullPointerException이 발생합니다. 구문booleanadd(Ee) 지정된 요소를 이 목록의 끝에 추가합니다. 유형 매개변수 E - 요소의 런타임 유형. 매개변수 e - 이 목록에 추가될 요소

1. wps 소프트웨어를 열고 wps 텍스트 작업 인터페이스로 들어갑니다. 2. 이 인터페이스에서 삽입 옵션을 찾으세요. 3. 삽입 옵션을 클릭하고 편집 영역에서 모양 옵션을 찾으세요. 4. 모양 옵션을 클릭하고 하위 메뉴에서 권장 옵션을 찾으세요. 5. 추천 옵션에서 중국 지도 옵션을 찾아보세요. 6. 중국 지도 옵션을 클릭하고 편집 입력 영역에서 마우스 왼쪽 버튼으로 드래그하여 필요한 중국 지도를 가져옵니다.

Microsoft SQL Server는 Microsoft에서 출시한 관계형 데이터베이스 관리 시스템으로, 통합 비즈니스 인텔리전스(BI) 도구를 사용하여 엔터프라이즈 수준의 데이터 관리를 제공하는 포괄적인 데이터베이스 플랫폼입니다. 관련 소프트웨어와의 통합 정도가 높습니다. SQL Server 데이터베이스 엔진은 관계형 데이터 및 구조화된 데이터에 대한 보다 안전하고 안정적인 저장소 기능을 제공하므로 사용자는 가용성이 높은 고성능 비즈니스용 데이터 응용 프로그램을 구축하고 관리할 수 있습니다.

MongoDB를 사용하여 데이터 일괄 가져오기 및 내보내기를 구현하는 방법 MongoDB는 비관계형 데이터베이스로서 데이터 저장 및 쿼리에 뛰어난 유연성과 성능 이점을 제공합니다. 데이터 일괄 가져오기 및 내보내기가 필요한 애플리케이션 시나리오의 경우 MongoDB는 해당 도구와 인터페이스도 제공합니다. 이 기사에서는 MongoDB를 사용하여 데이터 일괄 가져오기 및 내보내기를 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. MongoDB로 데이터를 일괄적으로 가져올 수 있습니다.

PHP를 사용하여 제품 재고 일괄 가져오기 기능을 구현하는 방법 전자상거래 플랫폼에서 제품 재고 일괄 가져오기는 일반적인 요구 사항입니다. 일괄 가져오기를 통해 가맹점에서는 다수의 상품에 대한 재고 정보를 신속하게 업데이트하고 업무 효율성을 높일 수 있습니다. 이 기사에서는 판매자의 재고 관리를 용이하게 하기 위해 PHP 프로그래밍 언어를 사용하여 이 기능을 구현하는 방법을 소개합니다. 먼저, 제품의 재고 정보를 저장할 테이블 파일을 생성해야 합니다. 이 양식 파일은 Excel 또는 CSV 형식일 수 있으며, 판매자는 제품명을 포함한 제품 정보를 입력할 수 있습니다.

SQLServer 또는 MySQL? 최근 연구는 최고의 데이터베이스 선택을 보여줍니다. 최근 인터넷과 빅데이터의 급속한 발전으로 인해 데이터베이스 선택은 기업과 개발자가 직면한 중요한 문제가 되었습니다. 많은 데이터베이스 중에서 가장 일반적이고 널리 사용되는 관계형 데이터베이스인 SQL Server와 MySQL은 논란의 여지가 많습니다. 그렇다면 SQLServer와 MySQL 중에서 어느 것을 선택해야 할까요? 최신 연구는 우리에게 이 문제를 밝혀줍니다. 먼저

인터넷의 대중화로 인해 웹사이트와 애플리케이션 개발은 많은 기업과 개인의 주요 사업이 되었습니다. PHP와 SQLServer 데이터베이스는 매우 중요한 두 가지 도구입니다. PHP는 동적 웹 사이트를 개발하는 데 사용할 수 있는 서버측 스크립팅 언어입니다. SQL Server는 Microsoft에서 개발한 관계형 데이터베이스 관리 시스템으로 광범위한 응용 프로그램 시나리오를 갖추고 있습니다. 이번 글에서는 PHP와 SQL Server의 개발 과정과 장점, 단점, 적용 방법에 대해 알아보겠습니다. 먼저,
