+ -
当前位置:首页 → 问答吧 → 求助MYSQL坐连接的问题

求助MYSQL坐连接的问题

时间:2010-07-17

来源:互联网



a表数据
id title
1  第一个标题
2  第二个标题

b表数据
aid content
1  第一个标题的内容
1  第一个标题的内容2
2  第二个标题的内容
2  第二个标题的内容2

我写的SQL语句是这样去左连接
"SELECT a.*,b.content FROM a表 a LEFT JOIN b表 b ON b.aid = a.id"
这样全部关联了,有2个重复的标题,2个不同的内容
得到的数据是这样
array(
    0 => array('id' => '1', 'title' => '第一个标题', 'content' => '第一个标题的内容');
    1 => array('id' => '1', 'title' => '第一个标题', 'content' => '第一个标题的内容2');
    2 => array('id' => '2', 'title' => '第二个标题', 'content' => '第二个标题的内容');
    3 => array('id' => '2', 'title' => '第二个标题', 'content' => '第二个标题的内容2');
);

怎么才能只关联b表的第一条数据呢?
希望得到这样的数据
array(
    0 => array('id' => '1', 'title' => '第一个标题', 'content' => '第一个标题的内容');
    1 => array('id' => '2', 'title' => '第二个标题', 'content' => '第二个标题的内容');
);

请求帮助下新手

作者: gyyst   发布时间: 2010-07-17

SELECT a.*,b.content FROM a表 a LEFT JOIN b表 b ON
(b.aid=a.id and b.content=(select content from b表 where aid=a.id limit 0,1))

作者: sindou   发布时间: 2010-07-22

如果b表里的aid+content不是唯一的话,上面的语句也有错。建议这种情况,在b表里加一个主键id,则可以准确并简化查询

作者: sindou   发布时间: 2010-07-22

SELECT a.*,b.content FROM a表 a LEFT JOIN b表 b ON
(b.bid = (select bid from b表 where aid=a.id limit 0,1))

作者: sindou   发布时间: 2010-07-22