Postgresql Postgres CTE:在非递归术语中,类型字符变化(255)[],但总体上类型字符变化[]

Postgresql Postgres CTE:在非递归术语中,类型字符变化(255)[],但总体上类型字符变化[],postgresql,graph-theory,common-table-expression,Postgresql,Graph Theory,Common Table Expression,我是SO和博士后的新手,请原谅我的无知。正在尝试使用与本文类似的解决方案获取postgres中图形的群集 唯一的区别是我的id是UUID,我使用varchar(255)存储这个id 当我尝试运行查询时,出现以下错误(但不确定如何强制转换): SQL状态:42804 提示:将非递归项的输出强制转换为正确的类型。 字符:81 我的代码(与上一篇文章基本相同): 尝试将递归和非递归术语中的SELECT列表强制转换为varchar WITH RECURSIVE search_graph(path, la

我是SO和博士后的新手,请原谅我的无知。正在尝试使用与本文类似的解决方案获取postgres中图形的群集

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

当我尝试运行查询时,出现以下错误(但不确定如何强制转换):

SQL状态:42804 提示:将非递归项的输出强制转换为正确的类型。 字符:81

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


尝试将递归和非递归术语中的
SELECT
列表强制转换为
varchar

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;

转到下一个错误:错误:运算符不存在:文本[]@>字符变化[]SQL状态:42883提示:没有与给定名称和参数类型匹配的运算符。您可能需要添加显式类型转换。人物:368@todd如果您在其他地方使用varchar,只需将其全部转换为varchar即可。更新。老实说,在PostgreSQL中,通常最好只使用文本,如果需要长度约束,请添加检查约束。否则,请找出
varchar(255)
的来源,并将其修复为与代码其余部分使用的无约束varchar一致。这对我很有用,谢谢!我将研究如何使用文本。。。由于声誉不佳,无法升级投票:(@todd您似乎试图编辑回复,以显示对
varchar(255)[
的强制转换的使用,而不是
varchar[]
。这就是您必须使用的吗?此强制转换对我从来没有任何影响,PostgreSQL 9.1:
array[guid]:varchar[]
(其中,
guid
是一个
varchar(32)
)-Postgres一再坚持第3列的字符类型是可变的(32)[]。然而,我能够骗PostgreSQL做正确的事情,比如:
array[guid||']::varchar[]
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;
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;