首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Postgres CTE :在非递归术语中键入character varying(255)[],但总体上键入character varying[]

Postgres CTE :在非递归术语中键入character varying(255)[],但总体上键入character varying[]
EN

Stack Overflow用户
提问于 2012-09-19 11:50:57
回答 1查看 9.1K关注 0票数 12

我是SO和postgres的新手,所以请原谅我的无知。尝试使用与本文Find cluster given node in PostgreSQL中的解决方案类似的解决方案在postgres中获取图的集群

唯一的区别是我的id是一个UUID,我使用varchar(255)来存储这个id

当我尝试运行查询时,我得到了以下错误(但不确定如何转换):

代码语言:javascript
复制
ERROR: recursive query "search_graph" column 1 has type character varying(255)[] in non-recursive term but type character varying[] overall

SQL state: 42804提示:将非递归项的输出转换为正确的类型。人物: 81

我的代码(与上一篇文章基本相同):

代码语言:javascript
复制
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;
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-19 12:13:06

尝试将递归和非递归项中的SELECT列表转换为varchar

代码语言:javascript
复制
WITH RECURSIVE search_graph(path, last_profile1, last_profile2) AS (
    SELECT ARRAY[id]::varchar[], id::varchar, id::varchar
    FROM node WHERE id = '408d6b12-d03e-42c2-a2a7-066b3c060a0b'
  UNION ALL
    SELECT (sg.path || m.toid || m.fromid)::varchar[], m.fromid::varchar, m.toid::varchar
    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;
票数 10
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12488282

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档