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)
13607정성태4/25/2024193닷넷: 2248.C# - 인터페이스 타입의 다중 포인터를 인자로 갖는 C/C++ 함수 연동
13606정성태4/24/2024206닷넷: 2247. C# - tensorflow 연동 (MNIST 예제)파일 다운로드1
13605정성태4/23/2024416닷넷: 2246. C# - Python.NET을 이용한 파이썬 소스코드 연동파일 다운로드1
13604정성태4/22/2024465오류 유형: 901. Visual Studio - Unable to set the next statement. Set next statement cannot be used in '[Exception]' call stack frames.
13603정성태4/21/2024719닷넷: 2245. C# - IronPython을 이용한 파이썬 소스코드 연동파일 다운로드1
13602정성태4/20/2024802닷넷: 2244. C# - PCM 오디오 데이터를 연속(Streaming) 재생 (Windows Multimedia)파일 다운로드1
13601정성태4/19/2024853닷넷: 2243. C# - PCM 사운드 재생(NAudio)파일 다운로드1
13600정성태4/18/2024888닷넷: 2242. C# - 관리 스레드와 비관리 스레드
13599정성태4/17/2024871닷넷: 2241. C# - WAV 파일의 PCM 사운드 재생(Windows Multimedia)파일 다운로드1
13598정성태4/16/2024898닷넷: 2240. C# - WAV 파일 포맷 + LIST 헤더파일 다운로드2
13597정성태4/15/2024881닷넷: 2239. C# - WAV 파일의 PCM 데이터 생성 및 출력파일 다운로드1
13596정성태4/14/20241073닷넷: 2238. C# - WAV 기본 파일 포맷파일 다운로드1
13595정성태4/13/20241053닷넷: 2237. C# - Audio 장치 열기 (Windows Multimedia, NAudio)파일 다운로드1
13594정성태4/12/20241069닷넷: 2236. C# - Audio 장치 열람 (Windows Multimedia, NAudio)파일 다운로드1
13593정성태4/8/20241085닷넷: 2235. MSBuild - AccelerateBuildsInVisualStudio 옵션
13592정성태4/2/20241224C/C++: 165. CLion으로 만든 Rust Win32 DLL을 C#과 연동
13591정성태4/2/20241200닷넷: 2234. C# - WPF 응용 프로그램에 Blazor App 통합파일 다운로드1
13590정성태3/31/20241079Linux: 70. Python - uwsgi 응용 프로그램이 k8s 환경에서 OOM 발생하는 문제
13589정성태3/29/20241155닷넷: 2233. C# - 프로세스 CPU 사용량을 나타내는 성능 카운터와 Win32 API파일 다운로드1
13588정성태3/28/20241270닷넷: 2232. C# - Unity + 닷넷 App(WinForms/WPF) 간의 Named Pipe 통신 [2]파일 다운로드1
13587정성태3/27/20241170오류 유형: 900. Windows Update 오류 - 8024402C, 80070643
13586정성태3/27/20241337Windows: 263. Windows - 복구 파티션(Recovery Partition) 용량을 늘리는 방법
13585정성태3/26/20241132Windows: 262. PerformanceCounter의 InstanceName에 pid를 추가한 "Process V2"
13584정성태3/26/20241252개발 환경 구성: 708. Unity3D - C# Windows Forms / WPF Application에 통합하는 방법파일 다운로드1
13583정성태3/25/20241472Windows: 261. CPU Utilization이 100% 넘는 경우를 성능 카운터로 확인하는 방법
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...