龙猫12138 2018-06-04 08:14 采纳率: 0%
浏览 2752
已采纳

mysql,a表如何使用b表的列作为where条件,下有详细

图片说明

图片说明

上面两表一张是a表一张是b表,b表是一张派生出来的表,如下图
图片说明
通过一个id,经过几次连接,就得到了b表

这个时候我希望可以用b表里面的lft和rgt作为查询条件,放到a表中去查出符合
a.lft>=b.lft and a.rgt<=b.rgt
的条目,比如说:
根据现在的b表,理想得到的结果应该是
图片说明
总共三个条目,第一条在21到22的范围,第二第三条在37到40的范围。

但是我尝试了几种做法,始终都得不到正确的结果,比如下图这种
图片说明
我用表a left join 表b ,然后用a.lft>=b.lft and a.rgt<=b.rgt,但是这样是错误的。原因很简单,看下图
图片说明
不写筛选条件,会发现,b表的列值除去两个其他全部是空的,这个情况下用a.lft>=b.lft and a.rgt<=b.rgt根本不可能得到正确的结果。

希望大家不吝赐教!

  • 写回答

3条回答 默认 最新

  • 斯洛文尼亚旅游 2018-06-04 08:23
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?