DBMS_LOCK を使用しない Oracle のデータベース スリープ関数
Oracle では、DBMS_LOCK.sleep 関数を使用すると、ユーザーは指定した期間実行を一時停止できます。ただし、この関数を使用するには、通常、プロシージャ所有者に特定の権限を付与する必要があります。
DBMS_LOCK.sleep 関数を利用する次の関数を考えてみましょう。
CREATE OR REPLACE FUNCTION MYSCHEMA.TEST_SLEEP ( TIME_ IN NUMBER ) RETURN INTEGER IS BEGIN DBMS_LOCK.sleep(seconds => TIME_); RETURN 1; EXCEPTION WHEN OTHERS THEN RAISE; RETURN 1; END TEST_SLEEP;
この関数は実行を効果的に一時停止しますが、使用するには、DBMS_LOCK へのアクセスを許可する必要があります。この要件を回避するための代替ソリューションが存在します。
IN_TIME INT; --num seconds v_now DATE; -- 1) Get the date & time SELECT SYSDATE INTO v_now FROM DUAL; -- 2) Loop until the original timestamp plus the amount of seconds <= current date LOOP EXIT WHEN v_now + (IN_TIME * (1/86400)) <= SYSDATE; END LOOP;
この代替方法では、LOOP を利用して実行を一時停止します。現在の日付と時刻を繰り返し取得し、目標遅延と比較します。現在の時間が遅延期間を超えるとループが終了し、特別な権限を必要とせずにスリープ機能の効果を効果的にシミュレートします。
以上がDBMS_LOCK を使用せずに Oracle でデータベース スリープ関数を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。