(Postgre)SQL中的一对多关系[英] One-to-Many relationships in (Postgre)SQL

本文是小编为大家收集整理的关于(Postgre)SQL中的一对多关系的处理方法,想解了(Postgre)SQL中的一对多关系的问题怎么解决?(Postgre)SQL中的一对多关系问题的解决办法?那么可以参考本文帮助大家快速定位并解决问题。

问题描述

我有两张桌子:

帖子:

 id | ... other stuff ... |     tags                         
----+---------------------+--------------
  1 |         ...         | <foo><bar>
  2 |         ...         | <foo><baz><blah>
  3 |         ...         | <bar><blah><goo>

和标签:

     tag         
--------------
 <foo>
 <bar>
 <baz>
 <blah>
 <goo>

posts.tags 和 tags.tag 都是文本类型.我想要的是从 tags.tag 到帖子中的行的关系,这样查询 <foo> 会给我对应于帖子 1 和 2 的行,查询 <blah> 给我 2 和 3, <bar> 给我 1 和 3,等等

我查看了外键,但我不确定它是否是我想要的.(老实说,我不确定它的作用).据我所知,外键必须等于表的主键/唯一列.但我想要的是 posts.tags ~ '.*<foo>.*' 等所有行.我还希望能够获取所有以 b 开头的标签,例如:

CREATE VIEW startswithB AS
SELECT tag
FROM tags
WHERE tag ~ '<b.*>';

SELECT DISTINCT * FROM posts, startswithB WHERE posts.tags ~ ('.*' || startswithB || '.*');

如何获得我正在寻找的关系?有可能吗?

编辑:

好的,我做了什么:

创建 post_tags:

SELECT posts.id, tags.tag 
INTO post_tags 
FROM posts, tags 
WHERE posts.tags ~ ('.*' || tags.tag || '.*');

选择所有带有标签<foo>的帖子:

SELECT *
FROM posts
WHERE posts.id IN (
    SELECT id
    FROM post_tags
    WHERE tag = '<foo>'
);

推荐答案

这里实际发生的是多对多关系.想一想:每个标签可以在多个帖子上,每个帖子可以有多个标签.

为此,正确的关系架构是在中间添加另一个表,如下所示:

CREATE TABLE post_tags (
  id INTEGER REFERENCES posts,
  tag VARCHAR REFERENCES tags
);

然后将 tags 列放到您的帖子表中.

这解决了您的所有问题,因为您可以通过在不同方向加入 post_tags 来获取帖子上的标签集或具有给定标签的帖子集.您还可以使用常规 LIKE 查询获取以某事物开头的标签列表,如果您在一个字段中连接一堆字符串,这将更加困难.

本文地址:https://www.itbaoku.cn/post/1763802.html