求助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))
(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))
(b.bid = (select bid from b表 where aid=a.id limit 0,1))
作者: sindou 发布时间: 2010-07-22
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28