INF: DTS 패키지 개발, 배포 및 성능

기술 자료 번역 기술 자료 번역
기술 자료: 242391 - 이 문서가 적용되는 제품 보기.
모두 확대 | 모두 축소

이 페이지에서

요약

이 문서의 목적은 개발 및 SQL Server 7.0 데이터 변환 서비스 (DTS) 패키지 배포를 위해 몇 가지 자세한 정보를 제공하는 것입니다. 또한 패키지 성능 향상에 대한 힌트는 제공됩니다.

SQL Server 2000이 이 주제에 대한 자세한 내용은 SQL Server 온라인 설명서를 참조하십시오.

추가 정보

가변 데이터 연결 만들기

DTS 패키지를 완전히 포함된 자체 단위가 있습니다. 심지어 연결 정보 UDLs 및 ODBC DSN 디자인 타임에 연결 속성 컬렉션에 모든 연결 정보를 읽습니다. 패키지를 만든 후 ODBC DSN 또는 UDL OLEDB 변경하면 해당 변경 패키지의 영향을 주지 않습니다. 이 패키지를 개발 환경에서 프로덕션 환경으로 마이그레이션할 때 기억해야 할 중요합니다.

SQL Server 데이터 연결을 사용할 때 (로컬을) 서버 이름을 쉽게 서버의 이름을 패키지 실행 시 확인할 수 있으므로 서버 간에 패키지를 이동할 수 있습니다. 이 방법의 한 가지 주의할 점은 패키지를 실행할 수 및 SQL을 편집할 필요하다는 것입니다 서버 컴퓨터 자체에.

ActiveX 스크립트 작업이나 래퍼 프로그램을 런타임에 패키지 속성을 수정할 수도 있습니다. 자체 내에서 패키지에서 수정하려면 데이터 펌프 작업 앞에 ActiveX 스크립트 작업 만들기 및 실행 중에 패키지를 수정할. 패키지 참조 DTSGlobalVariables.Parent에 대한 핸들을 가져올 수 있습니다. 있지만 약간의 프로그래밍 기술이 필요합니다 여기에서 패키지 속성을 변경할 수 있습니다.

다음 항목에서 해당 SQL 온라인 "ActiveX 스크립트 작업" ActiveX 스크립트 사용하여 데이터 원본 연결 속성을 변경하는 방법에 대한 예입니다:
   Function main()
   dim oPackage
   dim oConn

     'Get package object
     set oPackage = DTSGlobalVariables.parent
     'Get a handle to the desired connection.
     set oConn = oPackage.connections(1)
     'Modify the datasource.
     oConn.datasource = "newServerName"

     'Release object handles.
     set oPackage = nothing
     set oConn = nothing

    Main = DTSTaskExecResult_Success
End function
				
더 많은 코딩 마인드 많은 컨트롤을 추가하려는 경우 이를 실행하기 전에 외부 프로그램 사용하여 패키지를 수정하거나 처음부터 패키지를 만드는 것이 좋습니다.

로드 및 패키지 수정 프로그램을 만들려면 DTS 마법사 또는 DTS 디자이너를 사용하여 템플릿 패키지를 만들고 저장하십시오. 패키지를 로드합니다 및 원하는 속성을 수정하는 다음 패키지 개체에서 패키지를 실행하려면 Execute 메서드를 호출하는 VBA 프로그램을 작성하십시오.

처음부터 패키지를 생성하도록 프로그램을 만들려면 DTS 마법사 또는 DTS 디자이너를 사용하여 프로토타입 패키지를 만들고 로컬 SQL Server에 저장하십시오. 다음 Microsoft 기술 자료 문서에서 ScriptPkg 유틸리티를 패키지 코드에 대한 템플릿을 만들 수 있습니다.
239454INF: ScriptPkg 도구 도움말 사용할 DTS DTS 개체 모델 코드를 프로그래밍 생성한다
참조로 이 템플릿을 사용하여 사용자 입력을 기반으로 패키지를 생성하는 코드를 작성하십시오.

참고 앞에서 설명한 상황 중 모두에 대해 Visual Basic 프로젝트를 Microsoft DTSPackage 개체 라이브러리에 대한 참조가 있어야 합니다.

중요: Visual Basic 및 모니터링 패키지 또는 작업 이벤트 작성된 프로그램이나 에서 패키지를 실행하는 경우 패키지의 모든 단계에 주 스레드에서 실행할 수 있도록 구성되어야 합니다. 이 제한은 해당 이벤트에 여러 동시 호출을 제대로 처리를 방해하는 Visual Basic에서 것입니다.

패키지 전역 변수 사용하여 제어

전역 변수는 ActiveX 스크립트 작업, 워크플로 스크립트 및 ActiveX 변환을 통해 액세스할 수 있습니다. SQL 문 또는 연결 속성을 직접 사용할 수 없습니다. 그러나 ActiveX 스크립트 작업은 SQL 문 또는 전역 변수에 따라 연결 속성을 수정하는 데 사용할 수 있습니다. 다음은 SQL 문 'booktype' 라는 전역 변수를 기반으로 데이터 펌프 작업 변경하는 데 사용할 수 있는 ActiveX 스크립트 작업:
Function Main()
   dim oPackage
   dim oPump

        'Get a handle to the Package object.
	set oPackage = DTSGlobalVariables.Parent
	'Get a handle to the desired Datapump Task.
	set oPump = oPackage.Tasks("DTSTask_DTSDataPumpTask_1").CustomTask   
	'Alter the datapump SQL statement.
	oPump.SourceSQLStatement = "select * from pubs..titles WHERE type _
  = ''" + DTSGlobalVariables("booktype") + "''"
	Main = DTSTaskExecResult_Success
End Function
				
참고: 작업의 설명입니다 DTS 디자이너에서 표시되지만 직접 ActiveX 스크립트 작업에서 참조하는 데 사용할 수 없습니다. ActiveX 스크립트 작업을 참조하려면 작업의 이름을 사용해야 합니다. 워크플로 속성의 작업 살펴보고 이름을 단계 이름을 가져오는 데 필요한 권한입니다. 작업 이름 '단계' '작업' 로 대체할 단어 제외하고 단계는 동일합니다. 예를 들어, DTSStep_DTSDataPumpTask_1 DTSTask_DTSDataPumpTask_1 됩니다.

DTS 패키지 매개 변수 전달

DTSRun 프로그램 실행 시 패키지에 전달된 모든 명령줄 매개 변수를 허용하지 않습니다. 패키지 런타임 시 정보를 전달할 매개 변수는 합니다 수 파일에서 읽거나 데이터베이스 테이블에서 프로그래밍 방식으로 쿼리할.

참고: SQL Server 2000 도구를 또는 SQL Server 2000의 명명된 인스턴스를 기본 인스턴스로 설치한 SQL Server 7.0 서버에 설치된 경우 DTSRun 프로그램 명령 줄 매개 변수를 받아들일 수/A 데이터를 SQL Server 7.0 DTS 패키지에서 정의한 전역 변수는 명령줄에서 값을 전달합니다.

전역 변수를 설정하려면 텍스트 파일에서 한 줄을 읽는 동안 ActiveX 스크립트 작업 예는 다음과 같습니다. 이 문서의 "제어 패키지 함께 전역 변수" 절에 나와 있는 것처럼 패키지 동작을 수정하려면 이 전역 변수를 사용할 수 있습니다.
Function main()
  Dim fso	'This will serve as a handle to a file system object.
  Dim ofile	'Handle for accessing a file.

    'Get a file system object for manipulation files.
    Set fso = CreateObject("Scripting.FileSystemObject")

    'Open the text file.
    Set ofile = fso.OpenTextFile("c:\test.txt")

    'Read line from the file into the global variable.
    DTSGlobalVariables("myGlobalVar").Value = ofile.ReadLine

    'Close the "parameter" file.
    ofile.Close

    Main = DTSTaskExecResult_Success
End function
				
ActiveX 스크립트 작업 매개 변수를 SQL Server 테이블에서 읽는 방법을 보여 주는 예제입니다. 코드를 사용하여 my_param_table paramvalue 열의 값을 읽고 전역 변수를 설정하는 예제입니다. 이 예제에서는 SQL 분산 관리 개체 (DMO) SQL Server와 상호 작용하는 데 사용하지만 ADO (ActiveX 데이터 개체) 또는 다른 데이터 액세스 방법을 사용하여 동일한 작업을 수행할 수 있습니다.
Function main()
Dim oServer 		'DMO Server object.
Dim oResult		'Result set.
Dim sParamValue

	'Create a SQLDMO server object.
	Set oServer =  CreateObject("SQLDMO.SQLServer")

	' Make a connection to the local server.
	oServer.Connect ".", "sa"

	'Select the desired row from the table.
	set oResult = oServer.Databases("pubs").ExecuteWithResults_
("select  paramvalue from  my_param_table")

	'Retrieve the first row, first column from the results.
	sParamValue = oResult.GetColumnString (1,1)

	'Set the global variable.
	DTSGlobalVariables("MyGlobalVar").Value = sParamValue

	Main = DTSTaskExecResult_Success
End function
				

Visual Basic에서 쓰기 사용자 지정 DTS 작업

Visual Basic에서 사용자 지정 DTS 작업을 작성할 수 있습니다. UI 없이 Visual Basic의 사용자 지정 작업 예로는 SQL Server ROM에 \Devtools\Samples\DTS 디렉터리를 사용할 수 있습니다. DTS 사용자 지정 VBA 작업을 처리할 때 발생하는 몇 가지 일반적인 문제를 다음과가 같습니다.
  1. 인터페이스에서 모든 이벤트 DTS.CustomTaskUI 하는 같은 인터페이스를 구현하는 Visual Basic으로 작성된 사용자 지정 작업을 구현하는 또는 액세스 위반이 발생할 수 있습니다.
  2. UI를 통해 Visual Basic 사용자 지정 작업에 개발하는 경우 SQL Server 서비스 팩 1 (SP1) 적용하는 것이 좋습니다. SP1 UI 개발 쉽게 하기 위해 몇 가지 향상된 기능을 통합합니다.
  3. Visual Basic 작업 DTS 자유 스레드된 동안 스레드 아파트에 있습니다. Visual Basic으로 작성된 작업을 실행하려면 이를 주 스레드에서 실행되어야 하는 또는 액세스 위반이 발생할 수 있습니다. DTS 기본적으로 적절한 플래그를 설정합니다. 사용자가 이 플래그를 변경하면 안 됩니다.

코드 DTS 패키지 방법에 대한 정보 얻기

SQL 7 가지 몇 가지 예제 \Devtools\Damples\DTS 폴더 아래에 ROM에 있습니다. 이 샘플에서는 사용자 지정 작업 (Visual Basic) 사용자 지정 변환 (C++) 등이 있습니다. 일부 샘플 패키지를 실행 DTSDemo.exe 추출 자체 수도 있습니다.

가장 유용한 ScriptPkg, Dtsdemo.exe의 일부인 예입니다. ScriptPkg은 VBA 코드로 로컬 서버에 저장된 패키지를 변환합니다 VBA 소스 코드가 포함되어 있습니다. 이 예제에서는 가장 잘 사용됩니다.
  1. 기존 DTS 패키지를 스크립팅 VBA 예제를 만듭니다.
  2. DTS flatfile 드라이버가 코드 방법을 보여 주는, 어떤 SQL 온라인 설명되어 있지 않습니다.
  3. 이가 추가된 및 수 있는 SourceSafe 추적할 수 있도록 패키지를 텍스트로 변환.
ScriptPkg 예제에서는 몇 가지 알려진된 문제는 다음과 같습니다.
  1. 올바르게 스크립팅된 데이터 펌프 조회.
  2. 패키지를 너무 큰 다음 생성된 텍스트 한 함수에서 VBA 함수 줄 수에 제한이 인하여 처리할 수 없는 경우. 여러 함수를 직접 VBA 코드를 컴파일하려면 얻으려면 스크립트 파일에 나누어 할 것입니다.

DTS 패키지 성능 향상

병렬 로드 사용

DTS 여러 작업을 병렬로 실행할 수 있습니다. 그러나 DTS 패키지에서 각 연결에 대해서만 한 번에 한 스레드만을 처리할 수 있습니다. 즉, 다음 데이터 펌프 패키지의 모든 serialize됩니다.

B 및 B-> A-> A
B 및 C-> A-> A
B 및 C-> B-> A

차이가 없습니다 여부를 연결에 같거나 다른 아이콘을 사용할 수 있습니다.

병렬 작업 실행을 얻을 수 있는 유일한 방법은 다른 이름으로 동일한 데이터베이스에 여러 연결을 만들 수 있습니다. 예를 들어, A-> B 및 C D-> B 및 D 같은 서버 및 데이터베이스 연결을 다른 경우에도 병렬로 실행됩니다.

선행 제약 조건은 작업 실행 순서를 적용하고 필요에 따라 선택한 작업의 병렬 처리를 방지하기 위해 사용할 수 있습니다.

삽입 커밋 크기

데이터 펌프 작업에서 가장 중요한 매개 변수는 삽입 커밋 크기 것입니다. 이 속성은 대상 SQL Server 때만 관련이 있습니다. 트랜잭션을 커밋하기 전에 삽입된 대량 얼마나 많은 행이 있는 제어합니다. 기본적으로 이 0, 모든 행을 하나의 트랜잭션으로 일부입니다. 모든 오류 지닌 모든 변경 내용이 롤백됩니다 가장 안전한 설정을 때문입니다. 그러나 이를 수 매우 큰 트랜잭션 로그, 패키지는 취소될 때 응답 시간이 오래 이어질 필요하며 카운터 수 생산적인 실패할 전체 부하 큰 로드 끝에 단일 행으로 인해 경우. 행이 커밋됩니다 동안 현저하게 일시 각 커밋 간격이 끝날 때 볼 수 있습니다. 커밋 크기가 0 빠릅니다 있지만 10,000 다른 좋은 값, 줄이면 중 1000 및 1 순서대로 속도를. 1 1 행 모든 오류에서 롤백됩니다 때문에 유용합니다.

삽입 커밋 크기 0 이면 오류 수를 모든 숫자 > 1로 설정하면 효과가 있음을 유의하십시오. 오류 수를 트랜잭션 오류로 행 수 계산합니다.

SQL Server 7 .0의 데이터 변환 작업 속성의 고급 탭에서 데이터 이동 섹션에서 삽입 커밋 크기 값을 설정할 수 있습니다.

DTS 및 분산된 트랜잭션

DTS 패키지를 DTC 지원하는 이러한 공급자가 분산된 트랜잭션을 지원합니다. 작업 패키지와 단계 거래에 DTC 서비스를 실행하고 있어야 합니다. 또한 DTC 트랜잭션에 각 공급자가 지원해야 합니다.

패키지 속성의 고급 탭에서 패키지 트랜잭션 속성은 제어할 수 있습니다.

기본적으로 각 단계에서 패키지 고유한 트랜잭션을 처리하고 해당 트랜잭션을 통해 DTC 조정하지 않습니다. DTC 트랜잭션 작업에 참여 "트랜잭션이 있으면 조인" 확인란을 작업의 워크플로 속성을 설정해야 합니다. "이 단계를 성공적으로 완료했을 때 커밋 트랜잭션" 및 "롤백 트랜잭션 실패 시." 작업 다른 DTC 트랜잭션 옵션이 있습니다.

참고 Microsoft 트랜잭션 서버 (MTS) 패키지를 지원하지 않습니다.

오류 메시지가 나타난다

패키지 에서 연결에 대한 데이터베이스 서버에 대한 로컬 사용 및 다른 서버에서 패키지를 클릭한 다음 편집할 수 있으며 그 사람이 에서 변환의 찾을 때 다음과 같은 오류 메시지가 발생합니다.
오류 출처: Microsoft OLE DB 공급자에 대한 SQL Server 오류 설명: 'xxxxxxx' 로그인에서 요청한 데이터베이스를 열 수 없습니다. 로그인이 실패했습니다. "

속성

기술 자료: 242391 - 마지막 검토: 2002년 11월 25일 월요일 - 수정: 1.2
본 문서의 정보는 다음의 제품에 적용됩니다.
  • Microsoft SQL Server 7.0 Standard Edition
키워드:?
kbmt kbinfo KB242391 KbMtko
기계 번역된 문서
중요: 본 문서는 전문 번역가가 번역한 것이 아니라 Microsoft 기계 번역 소프트웨어로 번역한 것입니다. Microsoft는 번역가가 번역한 문서 및 기계 번역된 문서를 모두 제공하므로 Microsoft 기술 자료에 있는 모든 문서를 한글로 접할 수 있습니다. 그러나 기계 번역 문서가 항상 완벽한 것은 아닙니다. 따라서 기계 번역 문서에는 마치 외국인이 한국어로 말할 때 실수를 하는 것처럼 어휘, 구문 또는 문법에 오류가 있을 수 있습니다. Microsoft는 내용상의 오역 또는 Microsoft 고객이 이러한 오역을 사용함으로써 발생하는 부 정확성, 오류 또는 손해에 대해 책임을 지지 않습니다. Microsoft는 이러한 문제를 해결하기 위해 기계 번역 소프트웨어를 자주 업데이트하고 있습니다.

피드백 보내기

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com