sql >> データベース >  >> RDS >> PostgreSQL

postgresqlのアドバイザリロックのタイムアウト

    これは、DBMS_LOCK.REQUESTを適切にエミュレートしないラッパーのプロトタイプです。 -1つのタイプのロック(トランザクションスコープのアドバイザリロック)のみに制限されます。

    機能をOracleと完全に互換性があるようにするには、数百行が必要になります。しかし、それは始まりです。

    CREATE OR REPLACE FUNCTION
    advisory_xact_lock_request(p_key bigint, p_timeout numeric)
    RETURNS integer
    LANGUAGE plpgsql AS $$
    /*  Imitate DBMS_LOCK.REQUEST for PostgreSQL advisory lock. 
    Return 0 on Success, 1 on Timeout, 3 on Parameter Error. */
    DECLARE
        t0 timestamptz := clock_timestamp();
    BEGIN
        IF p_timeout NOT BETWEEN 0 AND 86400 THEN
            RAISE WARNING 'Invalid timeout parameter';
            RETURN 3;
        END IF;
        LOOP
            IF pg_try_advisory_xact_lock(key) THEN
                RETURN 0;
            ELSIF clock_timestamp() > t0 + (p_timeout||' seconds')::interval THEN
                RAISE WARNING 'Could not acquire lock in % seconds', p_timeout;
                RETURN 1;
            ELSE
                PERFORM pg_sleep(0.01); /* 10 ms */
            END IF;
        END LOOP;
    END;
    $$;
    

    次のコードを使用してテストします:

    SELECT CASE 
        WHEN advisory_xact_lock_request(1, 2.5) = 0
        THEN pg_sleep(120)
    END; -- and repeat this in parallel session 
    
    /* Usage in Pl/PgSQL */
    
    lkstat := advisory_xact_lock_request(lkhndl, lktimeout);
    



    1. 列の値に応じた条件付き ORDER BY

    2. 指定された名前と引数のタイプに一致する関数はありません

    3. 複数のインデックスと複数列のインデックス

    4. DD-Mon-YY形式でmySQLに日付を挿入できますか?