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

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条回答 默认 最新

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

报告相同问题?

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?