我有两张桌子:
CREATE TABLE article (
id serial NOT NULL,
title text,
tags integer[] -- array of tag id's from TAG table
)
CREATE TABLE tag (
id serial NOT NULL,
description character varying(250) NOT NULL
)..。并且需要根据文章的标题从文章的“标签integer[]”中的标签表中选择标签。
所以我试了一下
SELECT *
FROM tag
WHERE tag.id IN ( (select article.tags::int4
from article
where article.title = 'some title' ) );..。这给了我
错误:不能将类型integer[]转换为整数 第1行:...FROM标记,其中tag.id IN (从.
我在开发和生产环境中都被PostgreSql 8.3困住了。
发布于 2011-01-21 21:37:07
使用数组重叠操作符&&
SELECT *
FROM tag
WHERE ARRAY[id] && ANY (SELECT tags FROM article WHERE title = '...');使用contrib/intarray,您甚至可以很好地索引这类事情。
发布于 2011-01-21 16:58:40
请看一看"8.14.5。在数组中搜索“部分,但请考虑该部分末尾的提示:
提示:数组不是集合;搜索特定的数组元素可能是数据库错误设计的标志。考虑对数组元素的每个项使用一个单独的表,其中包含一行。这将更容易搜索,并且可能会对大量元素进行更好的扩展。
https://stackoverflow.com/questions/4761117
复制相似问题