V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
icerunz
V2EX  ›  PHP

求一条SQL语句,三个表关连查询的,谢谢。

  •  
  •   icerunz · 2011-07-23 19:22:09 +08:00 · 5734 次点击
    这是一个创建于 4905 天前的主题,其中的信息可能已经有所发展或是发生改变。
    各位,求一条SQL语句,我自己弄了半天弄出来的总是不对,结果都有重复项,麻烦帮我看下谢谢啊。

    三个表,content、relationship、meta,

    content是内容,主键cid;
    meta表存储分类的相应名称、类型等,主键mid;
    relationship是content和meta之间的关系,两个键,cid和对应的mid。

    求个SQL就是给一个分类名称,比方说default,查出相关的content内容和meta的内容放入数组。
    PS.有点像Wordpress里面的数据库结构,找了半天没找到WP是怎么实现的……弱啊

    我试着写了几个,但是都有点不对,JOIN没学好,麻烦大家帮助下,谢谢。
    7 条回复    1970-01-01 08:00:00 +08:00
    napoleonu
        1
    napoleonu  
       2011-07-23 21:20:34 +08:00
    select * from meta m right join relationship r on m.mid=r.mid join content c on r.cid=c.cid where m.name='default';
    napoleonu
        2
    napoleonu  
       2011-07-23 21:31:00 +08:00
    不好意思,写错了。
    napoleonu
        3
    napoleonu  
       2011-07-23 21:37:23 +08:00
    select * from meta m right join relationship r on m.mid=r.mid join content c on r.cid=c.cid where m.name='default' and m.mid is not null;

    希望没误导人,哈。
    Mai
        4
    Mai  
       2011-07-23 21:55:54 +08:00
    真业余 ~~
    Mai
        5
    Mai  
       2011-07-23 22:11:06 +08:00
    select * from meta m right join relationship r on m.mid=r.mid join content c on r.cid=c.cid where m.name='default';



    select * from meta m right join relationship r on m.mid=r.mid join content c on r.cid=c.cid where m.name='default' and m.mid is not null;

    没什么区别。
    icerunz
        6
    icerunz  
    OP
       2011-07-23 22:39:45 +08:00
    @Mai shy[-..-]
    icerunz
        7
    icerunz  
    OP
       2011-07-23 22:42:51 +08:00
    @napoleonu 嘿嘿,感谢,搞定了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3717 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 10:18 · PVG 18:18 · LAX 02:18 · JFK 05:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.