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

Postgresを使用したJSONグラフへの隣接リスト

    スキーマにPLV8を使用するソリューションは次のとおりです。

    まず、PLSQL関数と再帰CTEを使用してマテリアライズド・パスを作成します。

    CREATE OR REPLACE FUNCTION get_children(tag_id integer)
    RETURNS json AS $$
    DECLARE
    result json;
    BEGIN
    SELECT array_to_json(array_agg(row_to_json(t))) INTO result
        FROM (
    WITH RECURSIVE tree AS (
      SELECT id, name, ARRAY[]::INTEGER[] AS ancestors
      FROM tags WHERE parent_id IS NULL
    
      UNION ALL
    
      SELECT tags.id, tags.name, tree.ancestors || tags.parent_id
      FROM tags, tree
      WHERE tags.parent_id = tree.id
    ) SELECT id, name, ARRAY[]::INTEGER[] AS children FROM tree WHERE $1 = tree.ancestors[array_upper(tree.ancestors,1)]
    ) t;
    RETURN result;
    END;
    $$ LANGUAGE plpgsql;
    

    次に、上記の関数の出力からツリーを構築します。

    CREATE OR REPLACE FUNCTION get_tree(data json) RETURNS json AS $$
    
    var root = [];
    
    for(var i in data) {
      build_tree(data[i]['id'], data[i]['name'], data[i]['children']);
    }
    
    function build_tree(id, name, children) {
      var exists = getObject(root, id);
      if(exists) {
           exists['children'] = children;
      }
      else {
        root.push({'id': id, 'name': name, 'children': children});
      }
    }
    
    
    function getObject(theObject, id) {
        var result = null;
        if(theObject instanceof Array) {
            for(var i = 0; i < theObject.length; i++) {
                result = getObject(theObject[i], id);
                if (result) {
                    break;
                }   
            }
        }
        else
        {
            for(var prop in theObject) {
                if(prop == 'id') {
                    if(theObject[prop] === id) {
                        return theObject;
                    }
                }
                if(theObject[prop] instanceof Object || theObject[prop] instanceof Array) {
                    result = getObject(theObject[prop], id);
                    if (result) {
                        break;
                    }
                } 
            }
        }
        return result;
    }
    
        return JSON.stringify(root);
    $$ LANGUAGE plv8 IMMUTABLE STRICT;
    

    これにより、質問で言及されている必要なJSONが生成されます。お役に立てば幸いです。

    このソリューションがどのように機能するかについての詳細な投稿/内訳をここに書きました。 。



    1. PL/SQLの異なる列として1つの表から別の表に1つの列データを取得する方法

    2. javaString[]をpostgresプリペアドステートメントに設定中にエラーが発生しました

    3. PHPを使用してMySQLデータベースから値を取得する

    4. Oracleのvarchar(max)に相当するものは何ですか?