2016年11月17日 星期四

PostgreSQL Procedure 寫法 (判斷、迴圈、變數)

紀錄關於 postgresql 寫預存程序的寫法:

Procedure 基本宣告

CREATE OR REPLACE FUNCTION [預存函式名稱] (_param1 int, param2 int) RETURNS [回傳型態] AS
$$
    DECLARE --變數宣告型態區域 (變數一定要事先宣告)
        _id                  BIGINT;
        _screens             JSONB;

    BEGIN --宣告型態之後
        
        SELECT x INTO _screens FROM table WHERE 1=1; --注意, 這是把搜尋的資料指派進去 _screen 這個變數。

    END; --宣告結束
$$
LANGUAGE 'plpgsql';

內置判斷式 (判斷空值為例)

IF _screens IS NULL THEN -- 簡易判斷 _screen 這個變數是不是沒有查到資料

    RETURN jsonb_build_object('status', 'ERROR', 'message', 'UUID_NOT_FOUND'); --是就回傳 code
            
ELSE --沒有 else 就不要寫
       --else content

END IF;

迴圈 (次數)

FOR i IN 0..jsonb_array_length(_screens) - 1 LOOP
    RETURN NEXT _screens -> i ->> 'screen_id' :: TEXT; --i 會被指派數字進去
END LOOP;

迴圈 (迭代遍歷)

FOR
    _country_uuid, _country_name --迭代的 column
IN (SELECT country_uuid, name FROM table) --這裡可以丟只要符合 table 類型的資料進來迭代
LOOP --跑迴圈, for 宣告的底線變數會被授予迭代的值
    _data_array = array_append(_data_array, jsonb_build_object('uuid', _country_uuid, 'name', _country_name));
END LOOP;

完整範例

CREATE OR REPLACE FUNCTION [預存函式名稱] (_param1 int, param2 int) RETURNS [回傳型態] AS
$$
    DECLARE --變數宣告型態區域 (變數一定要事先宣告)
        _id                  BIGINT;
        _screens             JSONB;

    BEGIN --宣告型態之後
        
        SELECT x INTO _screens FROM table WHERE 1=1; --注意, 這是把搜尋的資料指派進去 _screen 這個變數。


        IF _screens IS NULL THEN -- 簡易判斷 _screen 這個變數是不是沒有查到資料
            RETURN jsonb_build_object('status', 'ERROR', 'message', 'UUID_NOT_FOUND');
        END IF;

        FOR i IN 0..jsonb_array_length(_screens) - 1 LOOP --迴圈
            _screen_id = _screens -> i ->> 'screen_id';
            _times := '[]';
            FOR
                _id
            IN SELECT
                id
            FROM reservation WHERE 1=1

            LOOP --迭代迴圈區域
                _times = jsonb_set(_times, '{2147483647}', jsonb_build_object(
                    'id', _id,
                    )
                );

            END LOOP;

            _data_array = array_append(_data_array, jsonb_build_object('screen_id', _screen_id, 'times', _times));

        END LOOP;

        RETURN json_build_object('status', 'SUCCESS', 'screens', _data_array);

        EXCEPTION --例外處理
            WHEN OTHERS THEN
                RETURN jsonb_build_object('status', 'ERROR', 'message', 'UN_KNOWN');
    END; --宣告結束
$$
LANGUAGE 'plpgsql';

沒有留言:

張貼留言

© Mac Taylor, 歡迎自由轉貼。
Background Email Pattern by Toby Elliott
Since 2014