Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)

C# - 닷넷 응용 프로그램에서 DB2 Express-C 데이터베이스 사용 (1)


테스트를 위해 DB2가 필요하던 참에 한번 정리해 봤습니다.

우선 DB2가 상용이긴 하지만 역시 Express류의 무료 버전을 제공하고 있습니다. 그것이 바로 "DB2 Express-C"인데, 다음의 경로에서 다운로드할 수 있습니다.

DB2 for Linux, UNIX and Windows
; http://www-01.ibm.com/software/data/db2/linux-unix-windows/downloads.html

IBM DB2 Express-C is a community edition of the DB2 10.1 (db2_v1012_winx64_expc.exe)
; http://www.ibm.com/services/forms/preLogin.do?source=swg-db2expressc

제 경우에는 "DB2 Express-C for Windows x64" 항목을 선택해서 다운로드했습니다. 실행하면 압축이 풀리고 설치 프로그램으로 자동 진행됩니다.

자, 그다음으로 SQL 서버의 SSMS 같은 도구가 있으면 좋을 텐데요. DB2의 경우 "IBM Data Studio"가 그 역할을 합니다.

IBM Data Studio
- Data Studio client and 3rd-party product extensions* Red Hat Linux®**, SUSE Linux**, Windows™
; http://www.ibm.com/developerworks/downloads/im/data/




IBM Data Studio를 실행하면 다음과 같이 그냥 비어있는 트리만 나옵니다. (그리고, 실행이 다소 느립니다.)

db2_ids_1.png

SSMS 사용자 경험에 비춰볼 때 DB 관리부터 낯설음을 느낍니다. SSMS의 경우 컴퓨터에 설치된 DB 서비스에 접속하고 그 상태에서 데이터베이스를 생성/삭제/변경하는 것이 일반적인데요. IBM Data Studio는 DB 서비스에 접속하는 방법은 없고 곧바로 DB를 생성해야 관리를 할 수 있는 방식입니다.

DB 생성은 다음의 글에서 잘 설명하고 있습니다.

Create a database with Data Studio for DB2
; http://www.db2teamblog.com/2010/04/create-database-with-data-studio-for.html

그리하여, 다음과 같이 New Database 메뉴를 선택하고,

db2_ids_2.png

저는 다음과 같은 정보를 채운 후 확인(Finish) 버튼을 눌렀습니다.

Host: localhost
Port: 50000
Instance name: DB2

User name: db2test
Password: ...[password]...

* 사용자 계정은 윈도우 계정과 통합됩니다. 따라서 위의 db2test 계정은 윈도우에서 미리 계정을 만들어 주어야 합니다.

그럼 이클립스 화면에 새로운 DB 생성을 위한 창이 하나 추가됩니다. 그 상태에서 다시 다음과 같은 식으로 정보를 입력하고,

Database name: testdb
Database location: d:

"Run" 버튼을 누르면 그제서야 DB가 생성됩니다.

주의할 것은 Database location 값으로 하위 폴더를 주면 안됩니다. 그런 경우 다음과 같은 예외가 발생합니다.

CREATE DATABASE "mytestdb" AUTOMATIC STORAGE YES ON 'D:\db2Instance' DBPATH ON 'D:\temp'

Failed to execute command. DAS returned the following error: sqlcode=-22220 output=SQL1052N 데이터베이스 경로 "D:\temp"이(가) 없습니다.


이 오류에 대해서는 다음의 글에서 원인을 설명해 주고 있습니다.

Failed to execute command.  DAS returned the following error: sqlcode=-22220 output=SQL1052N
; https://www.ibm.com/developerworks/mydeveloperworks/blogs/dylanskillsharing/entry/sql1052n_the_database_path_c_dylan_does_not_exist22?lang=en

DB2 데이터베이스가 생성될 경로를 하드 디스크 드라이브 문자까지만 입력할 수 있고, 하위 경로를 입력하면 저런 오류가 발생합니다. (사실, 이건 DB 생성 화면에서 알려주긴 합니다. 그렇긴 해도, 이것이 기본 동작이어야 할 이유가 뭔지 궁금하군요. ^^) 이 문제를 해결하려면 "Database location:" 값에 그냥 드라이브 위치만 지정해 주어야 합니다. 예를 들어 "D:"와 같은 식입니다. 아니면 DB2_CREATE_DB_ON_PATH 값을 설정해서 하위 폴더를 지정하는 것도 가능합니다.

그건 그렇고... ^^; DB 하나 생성하는데 정말 오래 걸리는군요. 아무리 VM에서 생성한 것이라고 해도 11분 씩이나 걸리다니.

암튼 우여 곡절 끝에 DB를 생성하고, IBM Data Studio에서 연결하면 다음과 같은 화면이 뜨고, "Connect"를 해주어야 DB와 연결되어 하위 정보를 볼 수 있습니다.

db2_ids_3.png




DB를 생성한 다음, 이제 테이블을 생성해야 하는데요. DB2의 경우 테이블이 스키마(Schema)에 종속되기 때문에 그에 앞서 스키마를 만들어 주어야 합니다.

이를 위해 DB 하위의 Schemas 노드에서 마우스 우측 버튼을 눌러 "Create Schema" 메뉴를 선택합니다. 그럼 기본 이름으로 Schema2라는 식의 새로운 스키마가 생성되지만, 하단의 속성 창에서 원하는 이름을 입력해 바꿀 수 있습니다.

db2_ids_4.png

문제는, 이렇게 생성된 스키마는 아직 DB에 반영된 것이 아니라는 점입니다. 그 사실을 위의 화면에서 Schema2와 NULLID, SQLJ,... 등등의 다른 스키마에 붙은 좌측 아이콘 모양이 틀리다는 것에서 짐작할 수 있습니다. DB에 반영하려면 아래의 그림에서 보이는 버튼을 눌러줘야 합니다.

db2_ids_5.png

IBM Data Studio에서 UI를 통해 하는 모든 일은 이렇게 DB에 반영하는 것이 별도로 분리되어 있습니다. 이것을 나쁘다고 할 수는 없습니다. 왜냐하면 변경 사항들을 별도로 "Changes Plans"으로 관리할 수 있고 나중에 모든 것을 한 번에 반영하는 것이 가능하기 때문입니다.

단지 혼란스러운 것은, UI를 통해 하는 것들은 2단계로 나뉘어져 있지만, 스크립트 쿼리 창을 띄워서 내리는 명령들은 곧바로 반영된다는 점입니다.

이하, 테이블 생성이나 칼럼 추가 등은 직관적으로 진행할 수 있습니다.




또 한 가지 알아두어야 할 것은, DB2에서 테이블 이름이나 칼럼 등을 대문자로 만드는 것이 좋습니다. 예를 들어, 테이블의 칼럼명을 IBM Data Studio에서는 "id" 소문자로 했고, 프로그램에서도 역시 소문자로 칼럼명을 지정했지만 다음과 같은 식으로 오류가 발생했습니다.

D:\temp>ConsoleApplication1.exe

Unhandled Exception: IBM.Data.DB2.DB2Exception: ERROR [42703] [IBM][DB2/NT64] SQL0206N  "ID"이(가) 사용된 컨텍스트에서 유효하지 않습니다.
   at IBM.Data.DB2.DB2Connection.HandleError(IntPtr hHandle, SQL_HANDLE hType, RETCODE retcode)
   at IBM.Data.DB2.DB2Command.a(Boolean A_0)
   at IBM.Data.DB2.DB2Command.b()
   at IBM.Data.DB2.DB2Command.ExecuteNonQuery()
   at ConsoleApplication1.Program.Main(String[] args) in d:\temp\Program.cs:line 35

이 오류를 수정하기 위해 다시 id를 ID로 바꿨고, 코드는 변경없이 정상적으로 수행되었습니다. 재미있는... DB2 규칙입니다. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 10/21/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 136  137  138  139  140  141  142  [143]  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1480정성태8/22/201337867개발 환경 구성: 194. 윈도우 서버의 80 포트에 대한 port forwarding 설정 방법파일 다운로드1
1479정성태8/14/201325197오류 유형: 183. IIS - 바인딩 추가 시 Object reference not set to an instance of an object 오류 [5]
1478정성태8/14/201328551오류 유형: 182. 윈도우 정품 활성화 오류 - 0x80070426
1477정성태8/14/201327406VC++: 71. codeplex의 Project Austin - 실감나게 책장 넘기는 표현
1476정성태8/13/201335862디버깅 기술: 55. Windbg - 윈도우 핸들 테이블 (2)
1475정성태8/12/201334951.NET Framework: 377. 프로세스가 종료된 후에도 소켓이 살아있다면?파일 다운로드1
1474정성태8/10/201331075오류 유형: 181. 윈도우 8 - WmiPrvSE.exe 프로세스가 CPU 소비하는 현상
1473정성태8/8/201327885VC++: 70. Win32 socket이 Thread-safe할까? [1]파일 다운로드1
1472정성태8/7/201326262.NET Framework: 376. .NET 2.0의 유니코드 관련 문자열 비교 오류
1471정성태8/7/201331014개발 환경 구성: 193. .aspx 확장자 대신 .html 확장자를 사용하는 방법
1470정성태8/6/201327045오류 유형: 180. DISM.exe 0xc1510111 실행 오류
1469정성태8/6/201324103.NET Framework: 375. System.Net.Sockets.Socket이 Thread-safe할까? [2]파일 다운로드1
1468정성태8/6/201322251오류 유형: 179. IIS - No connection could be made because the target machine actively refused it 127.0.0.1:80
1467정성태8/5/201325702Java: 16. IE에 로드된 Java Applet의 다운로드 위치를 확인하는 방법
1466정성태7/27/201331325.NET Framework: 374. C#과 비교한 C++ STL vector 성능 [7]파일 다운로드1
1465정성태7/18/201334585기타: 33. C:\Windows\Installer 폴더의 용량 줄이기 [3]
1464정성태7/15/201322861오류 유형: 178. Visual Studio 2012 Express - ImportCardinalityMismatchException
1463정성태7/15/201323557오류 유형: 177. [DBNETLIB][ConnectionOpen (Connect()).]SQL Server does not exist or access denied.
1462정성태7/5/201326829VC++: 69. geek스러운 C/C++ 퀴즈 문제 [2]
1461정성태6/27/201343369.NET Framework: 373. C# 문자열의 인코딩이란?
1460정성태6/17/201325254.NET Framework: 372. PerformanceCounter - Category does not exist. [1]
1459정성태6/15/201328936Windows: 74. 한글 키가 아닌 영문 키를 기본으로 선택하는 방법 [5]
1458정성태6/13/201329697.NET Framework: 371. CAS Lock 방식이 과연 성능에 얼마나 도움이 될까요? [1]파일 다운로드1
1457정성태6/13/201325912개발 환경 구성: 192. "Probabilistic Programming and Bayesian Methods for Hackers" 예제 코드 실행 방법
1456정성태6/5/201334551.NET Framework: 370. C# - WebKit .NET 사용 [2]파일 다운로드1
1455정성태6/1/201328371.NET Framework: 369. ThreadPool.QueueUserWorkItem의 실행 지연 [4]파일 다운로드1
... 136  137  138  139  140  141  142  [143]  144  145  146  147  148  149  150  ...