728x90
select A.NAME, A.ID, A.PARENT_OBJ, A.XTYPE, B.NAME, B.ID, B.PARENT_OBJ, B.XTYPE, C.NAME INDEX이
름, D.NAME COLUMN이름
from (SELECT * FROM sysobjects WHERE xtype ='U') A
     LEFT OUTER JOIN (SELECT * FROM SYSOBJECTS WHERE xtype in ('PK','UQ','C','F')) B ON A.ID
=B.PARENT_OBJ
     INNER JOIN SYSINDEXES C ON A.ID = C.ID
     INNER JOIN SYSCOLUMNS D ON A.ID = D.ID
WHERE C.indid = D.colid
ORDER BY A.ID, A.PARENT_OBJ, A.XTYPE
728x90

DML(DML Usage on an untyped XML column) 이라고 불리는 데이터 데이터 조작 처리 언어를 통해 우리는 데이터를 조회(SELECT)하고, 저장하고(INSERT)하고, 수정하고(UPDATE), 삭제(DELETE) 할 수 있습니다. SQL Server 2005 에서는 XML 문서를 처리하귀 위한 XML 이라는 새로운 데이터 형식이 제공되는데, XML 형식의 열의 값 또한 DML 을 이용하여 조회하거나 삭제, 수정, 입력 할 수 있습니다.

이 문서에서는 XML 형식의 열의 데이터를 찾고, 수정하고, 입력하고, 삭제하는 방법을 설명할 것입니다.


Step 1

다음의 쿼리를 실행하여 [test]라는 데이터베이스를 생성하고, [MyXMLtable] 테이블을 생성합니다. [MyXMLtable] 테이블은 XML 형식의 열을 포함하여 실제 XML 형식의 문서가 들어가게 됩니다.

USE [master]
GO
/****** Object:  Database [test]    Script Date: 08/24/2006 14:50:29 ******/
IF  EXISTS (SELECT name FROM sys.databases WHERE name = N'test'
)
DROP DATABASE
[test]
GO
CREATE DATABASE
test
GO
USE
[test]
GO
/****** Object:  Table [dbo].[MyXMLTable]    Script Date: 08/24/2006 14:50:14 ******/
IF  EXISTS (SELECT * FROM
sys.objects 
 
WHERE OBJECT_ID = OBJECT_ID(N'[dbo].[MyXMLTable]') AND type IN (N'U'
))
DROP TABLE
[dbo].[MyXMLTable]
GO
CREATE TABLE MyXMLTable (id INT, xmldat XML
)
GO
INSERT INTO MyXMLTable SELECT 1,
'
<?Names of Cat?> 
<Root>
 <!-- How to name your cat -->
<Cats> 
 <AmericanShorthair color="Grey" Friendly="No">Tiger</AmericanShorthair>
 <PersianHimalayan>MeowMeow</PersianHimalayan>
 <JapaneseBobtail>Rainbow River</JapaneseBobtail>
</Cats>
</Root>
'
GO
INSERT INTO MyXMLTable SELECT 2,
'
<?Names of Dog?> 
<Root>
 <!-- How to name your Dog -->
<Dog> 
 <GreyHound color="dottedwhite" Intelligence="None">oldie</GreyHound>
 <Pomeranian>Jackie</Pomeranian>
 <ShihTzu>Rainbow</ShihTzu>
</Dog>
</Root>
'
GO
  

 

Step 2

[id] 열의 값이 2인 행의 XML 문서에서, Dogs 요소의 모든 내용을 출력하기 위해서는 다음의 쿼리를 사용합니다.

USE test
GO
SELECT xmldat.query(' //Dog') FROM MyXMLTable  WHERE id=2
  

위의 쿼리는 아래와 같은 결과를 보여주게 됩니다.

<Dog><GreyHound color="dottedwhite" Intelligence="None">oldie</GreyHound>
   <Pomeranian>Jackie</Pomeranian><ShihTzu>Rainbow</ShihTzu></Dog>

이번에는 Cats 요소의 하위에 있는 PersianHimalayan 요소의 모든 내용을 출력해 보겠습니다. 다음의 쿼리를 실행해 주십시오.

USE test
GO
SELECT xmldat.query(' //Cats/PersianHimalayan') FROM MyXMLTable  WHERE id=1

위 쿼리는 다음과 같은 결과를 보여줍니다.

<PersianHimalayan>MeowMeow</PersianHimalayan>


Step 3

이번에는 id 열의 값이 1인 행의 XML 데이터에서 PersianHimalayan 요소의 내용을 삭제해 보겠습니다. XML 형식의 열의 데이터를 수정하기 위해서는 UPDATE 쿼리와 함께 특별한 문장을 함께 적어주어야 합니다. 바로 열이름.modify 인데, 이 부분을 UPDATE 쿼리와 함께 지정합니다.

USE test
GO
UPDATE
MyXMLTable 
SET xmldat.modify('delete /Root/Cats/PersianHimalayan ') WHERE id =1
  

위의 쿼리는 루트 요소 하위의 Cats 요소 하위 요소중 PersianHimalayan를 삭제하는 내용입니다. 위의 쿼리를 실행하고 다시 PersianHimalayan 요소를 출력하는 쿼리를 실행해 보겠습니다.

USE test
GO
SELECT xmldat.query(' //Cats/PersianHimalayan') FROM MyXMLTable  WHERE id=1

위의 쿼리를 실행하면 PersianHimalayan 요소를 삭제하였기 때문에, 아무런 결과도 출력하지 않습니다. 또한 다음의 쿼리를 실행하여 Cats 요소의 모든 내용을 출력하여 PersianHimalayan 요소의 존재를 확인할 수 있습니다.

USE test
GO
SELECT xmldat.query(' //Cats') FROM MyXMLTable  WHERE id=1
  

결과는 아래와 같습니다.

<Cats><AmericanShorthair color="Grey" Friendly="No">Tiger</AmericanShorthair><JapaneseBobtail>Rainbow River</JapaneseBobtail></Cats>

 

Step 4

이번에는 Dog 요소 하위에  "Mayliah" 라는 값을 가지는 Dalmation 요소 만드는 예제를 살펴보겠습니다.

USE test
GO
UPDATE
MyXMLTable 
SET xmldat.modify(
'insert <Dalmation>Mayliah</Dalmation> 
as first  
into   
(/Root/Dog)[1]'
) WHERE id =2
  

위에서 새로 추가한 요소를 확인하기 위해서 Dog 요소 전체의 내용을 살펴보겠습니다.

USE test
GO
SELECT xmldat.query('//Dog') FROM MyXMLTable  WHERE id=2
  

위 쿼리의 결과는 아래와 같이 Dog 요소 하위에 가장 먼저 새로운 내용이 들어가 있습니다.

<Dog><Dalmation>Mayliah</Dalmation><GreyHound color="dottedwhite" Intelligence="None">oldie</GreyHound>
   <Pomeranian>Jackie</Pomeranian><ShihTzu>Rainbow</ShihTzu></Dog>

이제 Cats 요소 하위에 존재하는 JapaneseBobtail 요소 바로앞에 새로운 요소를 삽입해 보겠습니다. 이번에 추가할 요소의 이름은 Oriental 이고 그 값은 "Serena" 을 가집니다.

USE test
GO
UPDATE
MyXMLTable 
SET xmldat.modify(
'insert <Oriental>Serena</Oriental> 
before (/Root/Cats/JapaneseBobtail)[1] '
) WHERE id = 1
  

위에서 새로 삽입한 요소의 확인을 위해 아래 쿼리를 실행합니다.

USE test
GO
SELECT xmldat.query(' //Cats') FROM MyXMLTable  WHERE id = 1
  

실행결과는 다음과 같습니다.

<Cats><AmericanShorthair color="Grey" Friendly="No">Tiger</AmericanShorthair>
   <Oriental>Serena</Oriental><JapaneseBobtail>Rainbow River</JapaneseBobtail></Cats>


Step 5

지금까지 우리는 XML 데이터를 삽입하고 삭제하는 방법을 살펴보았습니다.  데이터의 수정은 삭제와 삽입 작업의 조합으로 가능한데, 이는 DML 트리거나 같은 것입니다. Microsoft에서는 또한 replace 문장을 통해 데이터를 수정하는 방법을 제공하고 있습니다.

이제 AmericanShortHair 요소의 Friendly 속성의 값을 "No"에서 "Yes"로 변경하는 예제를 살펴보겠습니다.

USE test
GO
UPDATE
MyXMLTable 
SET xmldat.modify(
'
  replace value of (/Root/Cats/AmericanShorthair[@color="Grey"]/@Friendly)[1]
  with "Yes" '
) WHERE id = 1
  

아래 쿼리를 실행하여 성공적으로 데이터가 수정되었는지 살펴보겠습니다.

USE test
GO
SELECT xmldat.query(' //Cats') FROM MyXMLTable  WHERE id=1
  

실행 결과는 아래와 같습니다.

<PRE><Cats><AmericanShorthair color="Grey" Friendly="Yes">Tiger</AmericanShorthair><Oriental>Serena</Oriental><JapaneseBobtail>Rainbow River</JapaneseBobtail></Cats></PRE><PRE> </PRE>

영어 원문 : http://www.databasejournal.com/features/mssql/article.php/3629426

728x90
SQLLeader.com / 한대성 (dshan@adconsulting.co.kr)

 

 

SQL Server 2005 Bulk Insert 성능 비교를 다음과 같이 수행해 보았습니다.

임의로 10,000,000건의 텍스트 데이터를 만든 후, 각각의 방법을 이용하여 MSSQL Server 2005의 테이블에 넣는 방식입니다.

 

 

1. Source Text File 생성 스크립트 (VB.net Script : SSIS 내의 스크립트 작업을 이용하여 실행)

Imports System

Imports System.Data

Imports System.Math

Imports System.IO

Imports Microsoft.SqlServer.Dts.Runtime

 

Public Class ScriptMain

                  Public Sub Main()                     '

                   Dim str As String

                   Dim StrWriter As StreamWriter

                   Dim i As Integer

                   StrWriter = File.CreateText("D:\test.txt")

                   For i = 1 To 10000000

                    str = i.ToString + "|" + Convert.ToString(i * 2) + "|" + Convert.ToString(i * 3) + "|" + (Convert.ToInt32(i / 2)).ToString

                    StrWriter.WriteLine(str)

                   Next

                   StrWriter.Close()

 

                   Dts.TaskResult = Dts.Results.Success

                  End Sub

End Class

 

 

2. Text File Sample (d:\text.txt   : 10,000,000, 321 MB)

1|2|3|0

2|4|6|1

3|6|9|2

4|8|12|2

5|10|15|2

6|12|18|3

7|14|21|4

8|16|24|4

9|18|27|4

10|20|30|5

… … … …

9999995|19999990|29999985|4999998

9999996|19999992|29999988|4999998

9999997|19999994|29999991|4999998

9999998|19999996|29999994|4999999

9999999|19999998|29999997|5000000

10000000|20000000|30000000|5000000

 

3. Format File (d:\testImport-f-n.Fmt)

9.0

4

1       SQLBIGINT        0       8       "|"   1     c1       ""

2       SQLBIGINT        0       8       "|"   2     c2       ""

3       SQLBIGINT        0       8       "|"   3     c3       ""

4       SQLBIGINT        0       8       "\r\n"   4     c4       ""

 

 

4. 성능 비교

             1) OPENROWSET 이용

                - 수행 스크립트

CREATE TABLE testOpenRowset(c1 bigint, c2 bigint, c3 bigint, c4 bigint)

GO

DBCC DROPCLEANBUFFERS

DECLARE @start DATETIME

SET @start = getdate()

INSERT INTO testOpenRowset(c1, c2, c3, c4)

SELECT    t1.c1, t1.c2, t1.c3, t1.c4

FROM    OPENROWSET( BULK 'd:\test.txt',

        FORMATFILE = 'd:\testImport-f-n.Fmt') AS t1(c1, c2, c3, c4);

SELECT  getdate() - @start as ElapsedTime

DROP TABLE testOpenRowset

GO

 

                - 테스트 결과    (반복해서 12회 수행 후, 최대치 및 최소치를 제외한 10개의 값으로 평균을 계산)

순번

걸린 시간

데이터 유효성

1

00:01:50.203

 

2

00:01:55.187

 

3

00:01:52.377

 

4

00:01:58.030

 

5

00:01:52.237

 

6

00:01:58.937

 

7

00:02:08.953

최대치 - 제외

8

00:01:46.610

 

9

00:02:00.343

 

10

00:01:49.203

 

11

00:01:58.203

 

12

00:01:45.673

최소치 - 제외

평균

00:01:54.133

 

 

 

2) BULK INSERT 이용

                - 수행 스크립트

CREATE TABLE testBulkInsert(c1 bigint, c2 bigint, c3 bigint, c4 bigint)

GO

DBCC DROPCLEANBUFFERS

DECLARE @start DATETIME

SET @start = getdate()

BULK INSERT testBulkInsert

   FROM 'd:\test.txt'

   WITH (FORMATFILE='d:\testImport-f-n.Fmt')

SELECT  getdate() - @start as ElapsedTime

DROP TABLE testBulkInsert

GO

 

                - 테스트 결과    (반복해서 12회 수행 후, 최대치 및 최소치를 제외한 10개의 값으로 평균을 계산)

순번

걸린 시간

데이터 유효성

1

00:01:49.627

 

2

00:01:46.983

 

3

00:01:47.843

 

4

00:01:47.077

 

5

00:01:54.343

최대치 - 제외

6

00:01:45.967

 

7

00:01:49.500

 

8

00:01:48.457

 

9

00:01:44.953

 

10

00:01:52.687

 

11

00:01:45.737

 

12

00:01:44.153

최소치 - 제외

평균

00:01:47.883

 

 

 

3) BCP 이용

                - 수행 스크립트

CREATE TABLE testBCP(c1 bigint, c2 bigint, c3 bigint, c4 bigint)

GO

DBCC DROPCLEANBUFFERS

DECLARE @start datetime

SET @start = getdate()

EXEC master..xp_cmdshell 'bcp test.dbo.testBCP in d:\test.txt -T -b1000000 -fd:\testImport-f-n.Fmt'

SELECT  getdate() - @start as ElapsedTime

DROP TABLE testBCP

GO

 

                - 테스트 결과    (반복해서 12회 수행 후, 최대치 및 최소치를 제외한 10개의 값으로 평균을 계산)

순번

걸린 시간

데이터 유효성

1

00:02:10.530

최대치 - 제외

2

00:01:56.143

 

3

00:01:54.253

 

4

00:01:57.893

 

5

00:01:57.343

 

6

00:01:55.597

 

7

00:01:57.483

 

8

00:01:57.140

 

9

00:01:57.357

 

10

00:01:53.610

 

11

00:01:52.280

최소치 - 제외

12

00:01:58.437

 

평균

00:01:56.525

 

 

 

4) SSIS 이용 - FastParse = off (기본값)

- 수행 패키지

제어 흐름

데이터 흐름

 

                - 테스트 결과    (반복해서 12회 수행 후, 최대치 및 최소치를 제외한 10개의 값으로 평균을 계산)

순번

걸린 시간

데이터 유효성

1

00:01:05.938

최대치 - 제외

2

00:01:04.453

 

3

00:01:02.812

 

4

00:01:02.703

최소치 - 제외

5

00:01:04.672

 

6

00:01:03.328

 

7

00:01:04.359

 

8

00:01:02.922

 

9

00:01:03.234

 

10

00:01:04.219

 

11

00:01:05.891

 

12

00:01:04.562

 

평균

00:01:04.045

 

 

 

5) SSIS 이용 - FastParse = on        

                - 수행 패키지

제어 흐름

데이터 흐름

 

                - 테스트 결과    (반복해서 12회 수행 후, 최대치 및 최소치를 제외한 10개의 값으로 평균을 계산)

순번

걸린 시간

데이터 유효성

1

00:00:58.187

 

2

00:00:56.860

 

3

00:00:56.812

최소치 - 제외

4

00:00:57.141

 

5

00:00:57.344

 

6

00:00:56.907

 

7

00:00:56.453

 

8

00:00:58.953

최대치 - 제외

9

00:00:56.734

 

10

00:00:57.562

 

11

00:00:56.891

 

12

00:00:57.547

 

평균

00:00:57.163

 

 

 

5. 성능 비교 요약

데이터 처리 방식

걸린 시간

순위

OPENROWSET

00:01:54.133

4

BULK INSERT

00:01:47.883

3

BCP

00:01:56.525

5

SSIS ? FastParse=off

00:01:04.045

2

SSIS ? FastParse=on

00:00:57.163

1

 

            

             SSIS를 이용하는 방식이 BCP, OPENROWSET, BULK INSERT 등에 비해 약 48%정도 빠른 수행 결과를 나타냄. 

테스트 수행 참고 사이트 : http://weblogs.sqlteam.com/mladenp/articles/10631.aspx

+ Recent posts