Microsoft MVP성태의 닷넷 이야기
닷넷: 2133. C# - Oracle 데이터베이스의 Sleep 쿼리 실행하는 방법 [링크 복사], [링크+제목 복사],
조회: 12544
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

C# - Oracle 데이터베이스의 Sleep 쿼리 실행하는 방법

테스트를 위해 sleep이 필요했는데요, SQL Server의 경우 "WAITFOR" 명령어로 간단하게 해결을 했는데,

WAITFOR (Transact-SQL)
; https://learn.microsoft.com/en-us/sql/t-sql/language-elements/waitfor-transact-sql

아쉽게도 표준 SQL 쿼리가 아닌 탓에 오라클에는 없는 명령어입니다. 검색해 보니까 dbms_lock.sleep을 하면 된다고 하는데, 실제로 실행해 보면,

command = new OracleCommand();
command.Connection = oraConnection;
command.CommandText = "DBMS_LOCK.SLEEP(5);";
command.ExecuteNonQuery();

이런 오류가 발생합니다.

Oracle.ManagedDataAccess.Client.OracleException: 'ORA-00900: invalid SQL statement'

당연한 겁니다. ^^; SQL Server에서 WAITFOR는 "SQL Query"이지만, Oracle의 DBMS_LOCK.SLEEP은 SQL 쿼리가 아니라 Stored Procedure로 구현되었기 때문에 이런 식으로 실행해야 합니다.

OracleCommand command = new OracleCommand();
command.Connection = oraConnection;
command.CommandType = CommandType.StoredProcedure;
command.CommandText = "dbms_lock.sleep";
command.Parameters.Add(new OracleParameter("seconds", 1));

command.ExecuteNonQuery();

검색해 보면 쿼리로 실행하는 구문도 보이는데요, 그런 건 SQL 쿼리 문으로 처리되기 때문에 다음과 같이 실행하는 것도 무방합니다.

command = new OracleCommand();
command.Connection = oraConnection;
command.CommandText = "BEGIN DBMS_LOCK.SLEEP(5); END;";
command.ExecuteNonQuery();

그 외에, 저 명령어를 실행하려면 계정에 "SYS.DBMS_LOCK" 권한이 있어야 하므로 없다면 미리 부여를 해둬야 합니다.




참고로, sqlplus 등의 명령행에서도 dbms_lock.sleep을 직접 실행하면 SP2-0734 오류가 발생합니다.

SQL> dbms_lock.sleep(1);
SP2-0734: unknown command beginning "dbms_lock...." - rest of line ignored.

SQL> begin dbms_lock.sleep(1); end;
  2  /

PL/SQL procedure successfully completed.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/16/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  [83]  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11896정성태5/15/201925124개발 환경 구성: 440. C#, C++ - double의 Infinity, NaN 표현 방식파일 다운로드1
11895정성태5/12/201922657.NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제파일 다운로드1
11894정성태5/10/201924609VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [5]
11893정성태5/10/201920644오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면?
11892정성태5/10/201920547웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231)
11891정성태5/9/201923663.NET Framework: 831. (번역글) .NET Internals Cookbook Part 12 - Memory structure, attributes, handles
11890정성태5/8/201919383개발 환경 구성: 439. "Visual Studio Enterprise is required to execute the test." 메시지와 관련된 코드 기록
11889정성태5/8/201919435개발 환경 구성: 438. mstest, QTAgent의 로그 파일 설정 방법
11888정성태5/8/201937318.NET Framework: 830. C# - 비동기 호출을 취소하는 CancellationToken의 간단한 예제 코드 [1]파일 다운로드1
11887정성태5/8/201923117.NET Framework: 829. C# - yield 문을 사용할 수 있는 메서드의 조건
11886정성태5/7/201920191오류 유형: 534. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 [2]
11885정성태5/7/201917665오류 유형: 533. mstest.exe 실행 시 "File extension specified '.loadtest' is not a valid test extension." 오류 발생
11884정성태5/5/201922581.NET Framework: 828. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 두 번째 이야기
11883정성태5/3/201927584.NET Framework: 827. C# - 인터넷 시간 서버로부터 받은 시간을 윈도우에 적용하는 방법파일 다운로드1
11882정성태5/2/201924084.NET Framework: 826. (번역글) .NET Internals Cookbook Part 11 - Various C# riddles파일 다운로드1
11881정성태4/28/201924200오류 유형: 532. .NET Core 프로젝트로 마이그레이션 시 "CS0579 Duplicate 'System.Reflection.AssemblyCompanyAttribute' attribute" 오류 발생
11880정성태4/25/201919923오류 유형: 531. 이벤트 로그 오류 - Task Scheduling Error: m->NextScheduledSPRetry 1547, m->NextScheduledEvent 1547
11879정성태4/24/201928799.NET Framework: 825. (번역글) .NET Internals Cookbook Part 10 - Threads, Tasks, asynchronous code and others파일 다운로드2
11878정성태4/22/201924136.NET Framework: 824. (번역글) .NET Internals Cookbook Part 9 - Finalizers, queues, card tables and other GC stuff파일 다운로드1
11877정성태4/22/201924315.NET Framework: 823. (번역글) .NET Internals Cookbook Part 8 - C# gotchas파일 다운로드1
11876정성태4/21/201922524.NET Framework: 822. (번역글) .NET Internals Cookbook Part 7 - Word tearing, locking and others파일 다운로드1
11875정성태4/21/201924380오류 유형: 530. Visual Studo에서 .NET Core 프로젝트를 열 때 "One or more errors occurred." 오류 발생
11874정성태4/20/201924412.NET Framework: 821. (번역글) .NET Internals Cookbook Part 6 - Object internals파일 다운로드1
11873정성태4/19/201923115.NET Framework: 820. (번역글) .NET Internals Cookbook Part 5 - Methods, parameters, modifiers파일 다운로드1
11872정성태4/17/201923969.NET Framework: 819. (번역글) .NET Internals Cookbook Part 4 - Type members파일 다운로드1
11871정성태4/16/201921816.NET Framework: 818. (번역글) .NET Internals Cookbook Part 3 - Initialization tricks [3]파일 다운로드1
... 76  77  78  79  80  81  82  [83]  84  85  86  87  88  89  90  ...