WCF 채널 모델을 사용하여 Oracle Database에서 SQLEXECUTE 작업 실행
이 섹션에서는 채널을 통해 Oracle 데이터베이스에서 SQLEXECUTE 작업을 수행하는 방법을 보여 줍니다. SOAP 메시지에 메시지와 메시지 동작을 모두 지정해야 합니다. SQLEXECUTE 작업에 대한 자세한 내용은 WCF 서비스 모델을 사용하여 Oracle Database에서 SQLEXECUTE 작업 실행을 참조하세요.
SQLEXECUTE 메시지
다음 XML은 Oracle SEQUENCE의 다음 값을 반환하는 SQLEXECUTE 메시지를 보여줍니다.
<?xml version="1.0" encoding="utf-8" ?>
<!-- New Action: http://Microsoft.LobServices.OracleDB/2007/03/SQLEXECUTE -->
<SQLEXECUTE xmlns="http://Microsoft.LobServices.OracleDB/2007/03/SQLEXECUTE">
<SQLSTATEMENT>SELECT tid_seq.nextval id FROM dual</SQLSTATEMENT>
</SQLEXECUTE>
SQLEXECUTE는 매개 변수 스키마 요소와 여러 매개 변수 데이터 집합을 포함하는 매개 변수 블록을 지정할 수 있습니다. 표시된 메시지는 지정된 SQL 문을 단일 호출하기 위한 것이므로 매개 변수 스키마 및 매개 변수 블록을 지정하는 요소가 메시지 본문에서 생략됩니다. SQLEXECUTE 작업의 메시지 스키마에 대한 자세한 내용은 SQLEXECUTE 작업에 대한 메시지 스키마를 참조하세요.
SQLEXECUTE 작업 지정
메시지에 대한 작업을 지정해야 합니다. 다음 코드에서 발췌한 내용은 SQLEXECUTE 메시지에 대한 작업을 지정하는 방법을 보여줍니다.
Message messageIn = Message.CreateMessage(MessageVersion.Default, "http://Microsoft.LobServices.OracleDB/2007/03/SQLEXECUTE", readerIn);
SQLEXECUTE 메시지 보내기
다음 코드 발췌에서는 채널을 통해 Oracle 데이터베이스에서 SQLEXECUTE 작업을 호출하는 방법을 보여 줍니다.
// Create Endpoint
EndpointAddress address = new EndpointAddress("oracledb://ADAPTER");
// Create Binding
OracleDBBinding binding = new OracleDBBinding();
// Create Channel Factory
ChannelFactory<IRequestChannel> factory = new ChannelFactory<IRequestChannel>(binding, address);
factory.Credentials.UserName.UserName = "SCOTT";
factory.Credentials.UserName.Password = "TIGER";
factory.Open();
// Create Request Channel
IRequestChannel channel = factory.CreateChannel();
channel.Open();
// Send Request
System.Xml.XmlReader readerIn = System.Xml.XmlReader.Create("SQLExecute.xml");
Message messageIn = Message.CreateMessage(MessageVersion.Default, "http://Microsoft.LobServices.OracleDB/2007/03/SQLEXECUTE", readerIn);
Message messageOut = channel.Request(messageIn);
// Get Response XML
XmlReader readerOut = messageOut.GetReaderAtBodyContents();
// Get tid_seq SEQUENCE
string id = null;
XmlDocument doc = new XmlDocument();
doc.Load(readerOut);
XmlNodeList list = doc.GetElementsByTagName("ColumnValue");
if (list.Count > 0) id = list[0].InnerXml;
참고
SQLEXECUTE 작업은 항상 약한 형식의 결과 집합을 반환합니다.
참고 항목
WCF 채널 모델을 사용하여 Oracle Database 애플리케이션 개발
Oracle Database를 사용하여 채널 만들기