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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  114  115  116  117  118  [119]  120  ...
NoWriterDateCnt.TitleFile(s)
10950정성태5/2/201626364.NET Framework: 576. 기본적인 CLR Profiler 소스 코드 설명 [2]파일 다운로드2
10949정성태4/28/201619970.NET Framework: 575. SharedDomain과 JIT 컴파일파일 다운로드1
10948정성태4/28/201623936.NET Framework: 574. .NET - 눈으로 확인하는 SharedDomain의 동작 방식 [3]파일 다운로드1
10947정성태4/27/201621855.NET Framework: 573. .NET CLR4 보안 모델 - 4. CLR4 보안 모델에서의 조건부 APTCA 역할파일 다운로드1
10946정성태4/26/201624656VS.NET IDE: 106. Visual Studio 2015 확장 - INI 파일을 위한 사용자 정의 포맷 기능 (Syntax Highlighting)파일 다운로드1
10945정성태4/26/201618344오류 유형: 327. VSIX 프로젝트 빌드 시 The "VsTemplatePaths" task could not be loaded from the assembly 오류 발생
10944정성태4/22/201619592디버깅 기술: 80. windbg - 풀 덤프 파일로부터 텍스트 파일의 내용을 찾는 방법
10943정성태4/22/201624457디버깅 기술: 79. windbg - 풀 덤프 파일로부터 .NET DLL을 추출/저장하는 방법 [1]
10942정성태4/19/201619800디버깅 기술: 78. windbg 사례 - .NET 예외가 발생한 시점의 오류 분석 [1]
10941정성태4/19/201619664오류 유형: 326. Error MSB8020 - The build tools for v120_xp (Platform Toolset = 'v120_xp') cannot be found.
10940정성태4/18/201623005Windows: 116. 프로세스 풀 덤프 시간을 줄여 주는 Process Reflection [3]
10939정성태4/18/201624034.NET Framework: 572. .NET APM 비동기 호출의 Begin...과 End... 조합 [3]파일 다운로드1
10938정성태4/13/201623540오류 유형: 325. 파일 삭제 시 오류 - Error 0x80070091: The directory is not empty.
10937정성태4/13/201631753Windows: 115. UEFI 모드로 윈도우 10 설치 가능한 USB 디스크 만드는 방법
10936정성태4/8/201642495Windows: 114. 삼성 센스 크로노스 7 노트북의 운영체제를 USB 디스크로 새로 설치하는 방법 [3]
10935정성태4/7/201626834웹: 32. Edge에서 Google Docs 문서 편집 시 한영 전환키가 동작 안하는 문제
10934정성태4/5/201625466디버깅 기술: 77. windbg의 콜스택 함수 인자를 쉽게 확인하는 방법 [1]
10933정성태4/5/201631082.NET Framework: 571. C# - 스레드 선호도(Thread Affinity) 지정하는 방법 [8]파일 다운로드1
10932정성태4/4/201623390VC++: 96. C/C++ 식 평가 - printf("%d %d %d\n", a, a++, a);
10931정성태3/31/201623716개발 환경 구성: 283. Hyper-V 내에 구성한 Active Directory 환경의 시간 구성 방법 [3]
10930정성태3/30/201621604.NET Framework: 570. .NET 4.5부터 추가된 CLR Profiler의 실행 시 Rejit 기능
10929정성태3/29/201631799.NET Framework: 569. ServicePointManager.DefaultConnectionLimit의 역할파일 다운로드1
10928정성태3/28/201637507.NET Framework: 568. ODP.NET의 완전한 닷넷 버전 Oracle ODP.NET, Managed Driver [2]파일 다운로드1
10927정성태3/25/201626637.NET Framework: 567. System.Net.ServicePointManager의 DefaultConnectionLimit 속성 설명
10926정성태3/24/201626233.NET Framework: 566. openssl의 PKCS#1 PEM 개인키 파일을 .NET RSACryptoServiceProvider에서 사용하는 방법 [10]파일 다운로드1
10925정성태3/24/201620489.NET Framework: 565. C# - Rabin-Miller 소수 생성 방법을 이용하여 RSACryptoServiceProvider의 개인키를 직접 채워보자 - 두 번째 이야기파일 다운로드1
... 106  107  108  109  110  111  112  113  114  115  116  117  118  [119]  120  ...