首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >涉及integer[]的integer[]查询

涉及integer[]的integer[]查询
EN

Stack Overflow用户
提问于 2011-01-21 16:22:48
回答 2查看 3.1K关注 0票数 2

我有两张桌子:

代码语言:javascript
复制
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[]”中的标签表中选择标签。

所以我试了一下

代码语言:javascript
复制
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困住了。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-21 21:37:07

使用数组重叠操作符&&

代码语言:javascript
复制
SELECT *
    FROM tag
    WHERE ARRAY[id] && ANY (SELECT tags FROM article WHERE title = '...');

使用contrib/intarray,您甚至可以很好地索引这类事情。

票数 4
EN

Stack Overflow用户

发布于 2011-01-21 16:58:40

请看一看"8.14.5。在数组中搜索“部分,但请考虑该部分末尾的提示:

提示:数组不是集合;搜索特定的数组元素可能是数据库错误设计的标志。考虑对数组元素的每个项使用一个单独的表,其中包含一行。这将更容易搜索,并且可能会对大量元素进行更好的扩展。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4761117

复制
相关文章

相似问题

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