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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13693정성태7/24/20247239개발 환경 구성: 717. Visual Studio - C# 프로젝트에서 레지스트리에 등록하지 않은 COM 개체 참조 및 사용 방법파일 다운로드1
13692정성태7/24/20248014디버깅 기술: 199. Windbg - 리눅스에서 뜬 닷넷 응용 프로그램 덤프 파일에 포함된 DLL의 Export Directory 탐색
13691정성태7/23/20247372디버깅 기술: 198. Windbg - 스레드의 Win32 Message Queue 정보 조회
13690정성태7/23/20247005오류 유형: 919. Visual C++ 리눅스 프로젝트 - error : ‘u8’ was not declared in this scope
13689정성태7/22/20248514디버깅 기술: 197. Windbg - PE 포맷의 Export Directory 탐색
13688정성태7/21/20247617닷넷: 2281. C# - Lock / Wait 상태에서도 일부 Win32 메시지 처리파일 다운로드1
13687정성태7/19/20248047닷넷: 2280. C# - PostThreadMessage로 보낸 메시지를 Windows Forms에서 수신하는 방법파일 다운로드1
13686정성태7/19/20247842오류 유형: 918. Visual Studio - ATL Simple Object 추가 시 error C2065: 'IDR_...': undeclared identifier
13685정성태7/19/20247991스크립트: 66. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법 - 두 번째 이야기
13684정성태7/19/20248165닷넷: 2279. C# - 문자열 보간식 사례 (예: 조건 연산자 사용)
13683정성태7/18/20247642오류 유형: 917. ClrMD - Linux 환경의 .NET 5 덤프 분석 시 hang 현상
13682정성태7/18/20247856닷넷: 2278. WPF - 스레드에 종속되는 DependencyObject파일 다운로드1
13681정성태7/17/20247462닷넷: 2277. C# 13 - (2) 메서드 그룹의 자연 타입 개선 (메서드 추론 개선)파일 다운로드1
13680정성태7/16/20247840닷넷: 2276. C# - Method Group, Natural Type, function_type파일 다운로드1
13679정성태7/16/20246934Linux: 76. Linux - C++ (getaddrinfo 등을 담고 있는) libnss 정적 링크
13678정성태7/15/20247055VS.NET IDE: 191. Visual Studio 2022 - .NET 5 프로젝트를 Docker Support로 실행했을 때 오류
13677정성태7/15/20247134오류 유형: 916. MSBuild - CheckEolTargetFramework (warning NETSDK1138)
13676정성태7/14/20247319Linux: 75. gdb에서 glibc의 함수에 Breakpoint 걸기
13675정성태7/13/20249104C/C++: 166. C/C++ - DLL에서 template 함수를 export하는 방법 [1]파일 다운로드1
13674정성태7/13/20247986오류 유형: 915. Unhandled Exception: Microsoft.Diagnostics.NETCore.Client.ServerNotAvailableException: Unable to connect to Process
13673정성태7/11/20248430닷넷: 2275. C# 13 - (1) 신규 이스케이프 시퀀스 '\e'파일 다운로드1
13672정성태7/10/20247146닷넷: 2274. IIS - (프로세스 종료 없는) AppDomain Recycle
13671정성태7/10/20247261오류 유형: 914. Package ca-certificates is not installed.
13669정성태7/9/20247368오류 유형: 913. C# - AOT StaticExecutable 정적 링킹 시 빌드 오류
13668정성태7/8/20247394개발 환경 구성: 716. Hyper-V - Ubuntu 22.04 Generation 2 유형의 VM 설치
13667정성태7/7/20246610닷넷: 2273. C# - 리눅스 환경에서의 Hyper-V Socket 연동 (AF_VSOCK)파일 다운로드1
1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...