0

我四处寻找,一无所获。

我有 2 个表,不必为每个显示我需要以某种方式加入它们的帖子查询数据库。

我想从 pics 表中获取具有帖子表中字段urlid 的信息。pics现在这是我的问题:该pics字段是一个逗号分隔的“列表”(4,1 或 32,4,32,2),因为每个帖子通常都有不止一张图片。

表设置:

帖子:

 id | header | text | pics
| 1     xxx     xxx    3,1     
| 2     xxx     xxx    2,10,4     
| 3     xxx     xxx    16,17,18,19     
| 4     xxx     xxx    11,12,13        

图片:

id | name | url
| 1   xxx   xxx    
| 2   xxx   xxx        
| 3   xxx   xxx          
| 4   xxx   xxx          
| 10  xxx   xxx         
| 11  xxx   xxx         
| 12  xxx   xxx                  
| 13  xxx   xxx          
| 16  xxx   xxx          
| 17  xxx   xxx        
| 18  xxx   xxx        
4

1 回答 1

6

强烈建议您修复当前的数据库结构,以免将数据存储在逗号分隔的列表中。您的表结构应类似于以下内容:

CREATE TABLE posts
    (`id` int, `header` varchar(3), `text` varchar(3))
;

CREATE TABLE pics
    (`id` int, `name` varchar(3), `url` varchar(3))
;

CREATE TABLE post_pics
    (`post_id` int, `pic_id` int)
;

然后,您可以通过加入表格轻松获得结果:

select p.id,
  p.header,
  p.text,
  c.name,
  c.url
from posts p
inner join post_pics pp
  on p.id = pp.post_id
inner join pics c
  on pp.pic_id = c.id;

请参阅带有演示的 SQL Fiddle

如果您无法更改您的表,那么您应该可以使用以下命令进行查询FIND_IN_SET

select p.id, p.header, p.text, p.pics,
  c.id c_id, c.name, c.url
from posts p
inner join pics c
  on find_in_set(c.id, p.pics)

请参阅SQL Fiddle with Demo

编辑,如果您希望数据显示为逗号分隔的列表,那么您可以使用GROUP_CONCAT.

查询一:

select p.id,
  p.header,
  p.text,
  group_concat(c.name separator ', ') name,
  group_concat(c.url separator ', ') url
from posts p
inner join post_pics pp
  on p.id = pp.post_id
inner join pics c
  on pp.pic_id = c.id
group by p.id, p.header, p.text;

请参阅带有演示的 SQL Fiddle

查询 2:

select p.id, p.header, p.text, p.pics,
  group_concat(c.name separator ', ') name,
  group_concat(c.url separator ', ') url
from posts p
inner join pics c
  on find_in_set(c.id, p.pics)
group by p.id, p.header, p.text, p.pics;

请参阅带有演示的 SQL Fiddle

于 2013-06-04T17:09:59.907 回答