성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] Working with Rust Libraries from C#...
[정성태] Detecting blocking calls using asyn...
[정성태] 아쉽게도, 커뮤니티는 아니고 개인 블로그입니다. ^^
[정성태] 질문이 잘 이해가 안 됩니다. 우선, 해당 소스코드에서 ILis...
[양승조
] var대신 dinamic으로 선언해서 해결은 했습니다. 맞는 해...
[양승조
] 또 막혔습니다. ㅠㅠ var list = props[i].Ge...
[양승조
] 아. 감사합니다. 어제는 안됐던것 같은데....정신을 차려야겠네...
[정성태] "props[i].GetValue(props[i])" 코드에서 ...
[정성태] 저렇게 조각 코드 말고, 실제로 재현이 되는 예제 프로젝트를 압...
[정성태] Modules 창(Ctrl+Shift+U)을 띄워서, 해당 Op...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>닷넷에서 접근해보는 InterSystems의 IRIS Data Platform 데이터베이스</h1> <p> 처음 듣는 데이터베이스입니다. ^^ 아래의 경로를 통해 community 버전을 다운로드 신청할 수 있고,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > InterSystems IRIS Community Edition Download Registration ; <a target='tab' href='http://download.intersystems.com/download/register.csp'>http://download.intersystems.com/download/register.csp</a> </pre> <br /> 곧바로 "IRIS_Community-2020.1.0.215.0-win_x64.exe" 식의 파일을 내려받아 설치하면 되는데, 제 경우에는 그냥 기본값으로 진행을 했습니다.<br /> <br /> <img alt='iris_db_install_1.png' src='/SysWebRes/bbs/iris_db_install_1.png' /><br /> <br /> 이후, "시작" 메뉴를 통해 "Management Portal [IRIS]" 항목을 선택하면 웹 브라우저가 뜨고 관리 페이지로 접속이 됩니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> DB 설치는 그게 끝이고, 이후 간단한 실습을 위해 테이블을 생성해야 하는데,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > InterSystems IRIS Data Platform 2020.2 > Multi-model Data Access > InterSystems SQL Reference > SQL Commands > CREATE TABLE ; <a target='tab' href='https://docs.intersystems.com/irislatest/csp/docbook/DocBook.UI.Page.cls?KEY=RSQL_createtable'>https://docs.intersystems.com/irislatest/csp/docbook/DocBook.UI.Page.cls?KEY=RSQL_createtable</a> </pre> <br /> 어차피 생소한 DB라도 ANSI 규약의 SQL 쿼리 구문은 기본적으로 지원할 것이므로 해당 데이터베이스 문맥에서,<br /> <br /> <img onclick='toggle_img(this)' class='imgView' alt='iris_db_install_2.png' src='/SysWebRes/bbs/iris_db_install_2.png' /><br /> <br /> 실행해 주면 됩니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > CREATE TABLE Employee ( EMPID INT NOT NULL, NAME CHAR(100) NOT NULL, AGE INT, CONSTRAINT EMPLOYEEPK PRIMARY KEY (EMPID)) </pre> <br /> 한 가지 재미있는 점은, 생성된 테이블을 보면 기본적으로 BIGINT 타입의 "ID"가 있다는 정도!<br /> <br /> <img onclick='toggle_img(this)' class='imgView' alt='iris_db_install_3.png' src='/SysWebRes/bbs/iris_db_install_3.png' /><br /> <br /> <hr style='width: 50%' /><br /> <br /> IRIS DB 역시 닷넷으로 프로그래밍하는 방법은, ADO.NET의 사용법을 그대로 따릅니다. DB를 설치한 폴더로부터,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > C:\InterSystems\IRIS\dev\dotnet> <span style='color: blue; font-weight: bold'>tree</span> Folder PATH listing Volume serial number is D089-B7C9 C:. └─bin ├─Core21 │ └─Gateway │ └─runtimes │ └─win │ └─lib │ └─netstandard2.0 ├─CorePackages ├─v2.0.50727 ├─v4.0.30319 └─v4.5 </pre> <br /> 원하는 패키지를 선택하면 되는데, 이 글에서는 "v4.5"의 것으로 다음과 같이 CRUD 작업을 코딩해 봤습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > using InterSystems.Data.IRISClient; using System; using System.Data; namespace ConsoleApp1 { class Program { static void Main(string[] args) { TestDB(); } static void TestDB() { // Connecting to the InterSystems Database // <a target='tab' href='https://docs.intersystems.com/irislatest/csp/docbook/Doc.View.cls?KEY=BNET_connect#BNET_connect_connect'>https://docs.intersystems.com/irislatest/csp/docbook/Doc.View.cls?KEY=BNET_connect#BNET_connect_connect</a> using (IRISConnection sqlConnection = new IRISConnection()) { // 기본 포트: 51773 sqlConnection.ConnectionString = "Server=192.168.0.11; Port=51773; Namespace=USER;Password=SYS;User ID=_SYSTEM;"; sqlConnection.Open(); // Create IRISCommand insertCommand = new IRISCommand(); insertCommand.Connection = sqlConnection; insertCommand.CommandText = "INSERT INTO Employee(ID, EMPID, NAME, AGE) VALUES (?, ?, ?, ?)"; insertCommand.Parameters.Add("ID", IRISDbType.BigInt); insertCommand.Parameters.Add("EMPID", IRISDbType.Int); insertCommand.Parameters.Add("NAME", IRISDbType.NVarChar, 100); insertCommand.Parameters.Add("AGE", IRISDbType.Int); string nameValue = "Name" + Guid.NewGuid().ToString(); insertCommand.Parameters[1].Value = (int)DateTime.Now.Ticks; insertCommand.Parameters[2].Value = nameValue; insertCommand.Parameters[3].Value = 10; int affected = insertCommand.ExecuteNonQuery(); Console.WriteLine("[INSERT] # of affected row: " + affected); // Update IRISCommand updateCommand = new IRISCommand(); updateCommand.Connection = sqlConnection; updateCommand.CommandText = "UPDATE Employee SET AGE=? WHERE NAME=?"; updateCommand.Parameters.Add("AGE", IRISDbType.Int); updateCommand.Parameters.Add("NAME", IRISDbType.NVarChar, 100); updateCommand.Parameters[0].Value = 20; updateCommand.Parameters[1].Value = nameValue; affected = updateCommand.ExecuteNonQuery(); Console.WriteLine("[UPDATE] # of affected row: " + affected); // Select - ExecuteScalar IRISCommand selectCommand = new IRISCommand(); selectCommand.Connection = sqlConnection; selectCommand.CommandText = "SELECT count(*) FROM Employee"; object result = selectCommand.ExecuteScalar(); Console.WriteLine("[SELECT] # of records: " + result); // Select - DataTable DataSet ds = new DataSet(); IRISDataAdapter da = new IRISDataAdapter("SELECT * FROM Employee", sqlConnection); da.Fill(ds, "mytable"); DataTable dt = ds.Tables["mytable"]; foreach (DataRow dr in dt.Rows) { Console.WriteLine(string.Format("Name = {0}, Age = {1}", dr["NAME"], dr["AGE"])); } // Delete IRISCommand deleteCommand = new IRISCommand(); deleteCommand.Connection = sqlConnection; deleteCommand.CommandText = "DELETE FROM Employee WHERE NAME=?"; deleteCommand.Parameters.Add("NAME", IRISDbType.NVarChar, 100); deleteCommand.Parameters[0].Value = nameValue; affected = deleteCommand.ExecuteNonQuery(); Console.WriteLine("[DELETE] # of affected row: " + affected); } } } } </pre> <br /> (<a target='tab' href='https://www.sysnet.pe.kr/bbs/DownloadAttachment.aspx?fid=1613&boardid=331301885'>첨부 파일은 이 글의 예제 코드를 포함</a>합니다.)<br /> <br /> 보는 바와 같이 일반적인 ADO.NET과 사용법은 같지만, SQL Server만 다루던 개발자라면 Parameterized Query에 이름을 지정할 수 없다는 것을 유의해야 합니다. 예를 들어, 본문에서 "INSERT INTO Employee(ID, EMPID, NAME, AGE) VALUES (?, ?, ?, ?)" 쿼리를 보였는데, 따라서 Parameters 컬렉션에 (이름이 없으므로) 들어가는 순서대로 "?"에 매핑이 된다는 것을 신경 써야 합니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> 한 가지 좀 안 좋은 면이 있는데요, IRISConnection 단위로 이전에 수행되지 않은 쿼리인 경우 언제나 "System.ArgumentNullException" 예외가 InterSystems.Data.IRISClient.CachedPrepareCollection.GetStatement 메서드에서 발생합니다. (그러니까, 현실적으로 거의 항상 발생한다고 보면 됩니다.)<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > internal CachedPrepare GetStatement(string sqlText, IRISCommand cmd) { CachedPrepare prepare2; this.rwl.EnterReadLock(); try { object obj2 = this.sqlToId[sqlText]; // 수행된 적이 없는 쿼리는 obj2 == null <span style='color: blue; font-weight: bold'>CachedPrepare prepare = (CachedPrepare) base[obj2];</span> // System.ArgumentNullException 예외 발생 if (prepare != null) { if (prepare.ownedBy == null) { prepare.ownedBy = cmd; this.unownedCnt--; prepare.refCount++; } else { return null; } } prepare2 = prepare; } catch (Exception) { prepare2 = null; } finally { this.rwl.ExitReadLock(); } return prepare2; } </pre> <br /> try/catch가 되어 있기 때문에 실행에 지장은 주지 않지만, Debug 창에 System.ArgumentNullException 오류가 끊임없이 나오는 것은 별로 좋은 사용자 경험은 아닙니다. 게다가 만약 해당 Exception을 "<a target='tab' href='https://www.sysnet.pe.kr/2/0/622'>Break When Thrown</a>"으로 지정해 놓았다면 매번 비주얼 스튜디오는 다음의 예외 창을 보여줍니다. (따라서 반드시 해당 옵션을 꺼두어야 합니다.)<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > System.ArgumentNullException HResult=0x80004003 Message=Key cannot be null. Parameter name: key Source=mscorlib StackTrace: at System.Collections.Hashtable.get_Item(Object key) This exception was originally thrown at this call stack: System.Collections.Hashtable.this[object].get(object) </pre> <br /> <hr style='width: 50%' /><br /> <br /> <span style='text-decoration: line-through'>참고로, 아래의 문서를 보면,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Using Cache ADO.NET Managed Provider Classes ; <a target='tab' href='https://cedocs.intersystems.com/latest/csp/docbook/Doc.View.cls?KEY=GBMP_ado#GBMP_ado_intro'>https://cedocs.intersystems.com/latest/csp/docbook/Doc.View.cls?KEY=GBMP_ado#GBMP_ado_intro</a> Installing Cache ; <a target='tab' href='http://www.hardhats.org/projects/New/InstallCache.html#download-and-install-cach%C3%A9-on-microsoft-windows'>http://www.hardhats.org/projects/New/InstallCache.html#download-and-install-cach%C3%A9-on-microsoft-windows</a> </pre> <br /> "Cache" 접두사로 시작하는 Data Provider도 있었던 것 같습니다.<br /></span> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1296
(왼쪽의 숫자를 입력해야 합니다.)