성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] VT sequences to "CONOUT$" vs. STD_O...
[정성태] NetCoreDbg is a managed code debugg...
[정성태] Evaluating tail call elimination in...
[정성태] What’s new in System.Text.Json in ....
[정성태] What's new in .NET 9: Cryptography ...
[정성태] 아... 제시해 주신 "https://akrzemi1.wordp...
[정성태] 다시 질문을 정리할 필요가 있을 것 같습니다. 제가 본문에...
[이승준] 완전히 잘못 짚었습니다. 댓글 지우고 싶네요. 검색을 해보...
[정성태] 우선 답글 감사합니다. ^^ 그런데, 사실 저 예제는 (g...
[이승준] 수정이 안되어서... byteArray는 BYTE* 타입입니다...
글쓰기
제목
이름
암호
전자우편
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'>C# - Oracle 데이터베이스의 Sleep 쿼리 실행하는 방법</h1> <p> 테스트를 위해 sleep이 필요했는데요, SQL Server의 경우 "WAITFOR" 명령어로 간단하게 해결을 했는데,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > WAITFOR (Transact-SQL) ; <a target='tab' href='https://learn.microsoft.com/en-us/sql/t-sql/language-elements/waitfor-transact-sql'>https://learn.microsoft.com/en-us/sql/t-sql/language-elements/waitfor-transact-sql</a> </pre> <br /> 아쉽게도 표준 SQL 쿼리가 아닌 탓에 오라클에는 없는 명령어입니다. 검색해 보니까 dbms_lock.sleep을 하면 된다고 하는데, 실제로 실행해 보면,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > command = new OracleCommand(); command.Connection = oraConnection; command.CommandText = "DBMS_LOCK.SLEEP(5);"; command.ExecuteNonQuery(); </pre> <br /> 이런 오류가 발생합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Oracle.ManagedDataAccess.Client.OracleException: 'ORA-00900: invalid SQL statement' </pre> <br /> 당연한 겁니다. ^^; SQL Server에서 WAITFOR는 "SQL Query"이지만, Oracle의 DBMS_LOCK.SLEEP은 SQL 쿼리가 아니라 Stored Procedure로 구현되었기 때문에 이런 식으로 실행해야 합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > OracleCommand command = new OracleCommand(); command.Connection = oraConnection; <span style='color: blue; font-weight: bold'>command.CommandType = CommandType.StoredProcedure;</span> <span style='color: blue; font-weight: bold'>command.CommandText = "dbms_lock.sleep";</span> <span style='color: blue; font-weight: bold'>command.Parameters.Add(new OracleParameter("seconds", 1));</span> command.ExecuteNonQuery(); </pre> <br /> 검색해 보면 쿼리로 실행하는 구문도 보이는데요, 그런 건 SQL 쿼리 문으로 처리되기 때문에 다음과 같이 실행하는 것도 무방합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > command = new OracleCommand(); command.Connection = oraConnection; <span style='color: blue; font-weight: bold'>command.CommandText = "BEGIN DBMS_LOCK.SLEEP(5); END;";</span> command.ExecuteNonQuery(); </pre> <br /> 그 외에, 저 명령어를 실행하려면 계정에 <a target='tab' href='https://www.sysnet.pe.kr/2/0/13392#dbms_lock'>"SYS.DBMS_LOCK" 권한</a>이 있어야 하므로 없다면 미리 부여를 해둬야 합니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> 참고로, sqlplus 등의 명령행에서도 dbms_lock.sleep을 직접 실행하면 SP2-0734 오류가 발생합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > SQL> <span style='color: blue; font-weight: bold'>dbms_lock.sleep(1);</span> SP2-0734: unknown command beginning "dbms_lock...." - rest of line ignored. SQL> <span style='color: blue; font-weight: bold'>begin dbms_lock.sleep(1); end;</span> 2 / PL/SQL procedure successfully completed. </pre> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1196
(왼쪽의 숫자를 입력해야 합니다.)