私はSOとpostgresを初めて使用するので、無知を許してください。この投稿のソリューションと同様のソリューションを使用して、postgresでグラフのクラスターを取得しようとしていますPostgreSQLでノードを指定してクラスターを検索します
唯一の違いは、私のIDがUUIDであり、このIDを格納するためにvarchar(255)を使用していることです。
クエリを実行しようとすると、次のエラーが発生します(ただし、キャスト方法がわかりません)。
ERROR: recursive query "search_graph" column 1 has type character varying(255)[] in non-recursive term but type character varying[] overall
SQLの状態:42804ヒント:非再帰的な用語の出力を正しいタイプにキャストします。キャラクター:81
私のコード(基本的に前の投稿と同じ):
WITH RECURSIVE search_graph(path, last_profile1, last_profile2) AS (
SELECT ARRAY[id], id, id
FROM node WHERE id = '408d6b12-d03e-42c2-a2a7-066b3c060a0b'
UNION ALL
SELECT sg.path || m.toid || m.fromid, m.fromid, m.toid
FROM search_graph sg
JOIN rel m
ON (m.fromid = sg.last_profile2 AND NOT sg.path @> ARRAY[m.toid])
OR (m.toid = sg.last_profile1 AND NOT sg.path @> ARRAY[m.fromid])
)
SELECT DISTINCT unnest(path) FROM search_graph;