免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1272 | 回复: 1

【已解决】求一查询 [复制链接]

论坛徽章:
0
发表于 2012-08-04 14:23 |显示全部楼层
本帖最后由 cenalulu 于 2012-08-04 21:31 编辑

news(news_id), image(msg_id, path, type_id), image_type(type_id, name) 三表
其中image.msg_id可能是news_id或者是别的表的id, 用type_id 来区别.

想查出10个news,

1. 如果在image里有记录则取出,
2. 没有就空
3. 每个news只有一个这类图, 不用约束数量, 但是有可能这个news有别的类型的图也在这个image表里.

select n.news_id, i.path
from news n
left   join image i on nnews_id = i.msg_id
left   join image_type t on i.type_id = t.type_id
where t.name = 'news_front_image'

limit 10

这个不多啊, 但是希望能帮助理解表的关系.


求查询语句, 性能尽量好, 谢谢!

论坛徽章:
0
发表于 2012-08-04 14:57 |显示全部楼层
哦, 好像把类型判断放在join后就可以了

select n.news_id, i.path
from news n
left   join image i on nnews_id = i.msg_id and i.type_id = (select type_id from image_type where name = 'news_front_image')
limit 10
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP