欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

thinkphp四级关联查询怎么写 ,在线等

程序员文章站 2022-06-13 08:46:56
...
thinkphp四级关联查询怎么写?关系:A在B的aid,B在C的bid,C在D的Cid,怎样关联起来呢?
A-->B-->C-->D
M("D")->jion("A on B.aid=A.id)->jion("B on C.bid=B.id)->jion("C on D.cid=C.id) 这样写不对


回复讨论(解决方案)

你的表达式写错了
->join('A on B.aid=A.id')->join("B on C.bid=B.id")->join("C on D.cid=C.id")

join() 里面直接写join吧

应该是join

你jion 直接改成join句子就对了 ,没问题!

你的表达式写错了
->join('A on B.aid=A.id')->join("B on C.bid=B.id")->join("C on D.cid=C.id")


这样写不行,如果是->join('A on B.aid=A.id')->join("C on B.bid=C.id")->join("D on B.cid=D.id") 这样可以。

你jion 直接改成join句子就对了 ,没问题!


left、right、inner,不写都不对

你看看最后产生的 SQL 指令
是形如这样的,就符合你的要求了

select * from A left join b on a.id=b.aid    left join c on b.id=c.bid    left join d on d.id=d.cid

你看看最后产生的 SQL 指令
是形如这样的,就符合你的要求了

select * from A left join b on a.id=b.aid    left join c on b.id=c.bid    left join d on d.id=d.cid

产生的sql是这种,但是它报错了,[Err] 1054 - Unknown column

1054 - Unknown column 未知的列
显然是有字段名写错了,请仔细检查一下

1054 - Unknown column 未知的列
显然是有字段名写错了,请仔细检查一下


我也知道报这个错是名字写错了,但是我核对了好几遍,确定名字没错

你把产生的 sql 指令放到 mysql 管理器或 phpmyadmin 中执行一下
看看原始的错误信息是什么

你把产生的 sql 指令放到 mysql 管理器或 phpmyadmin 中执行一下
看看原始的错误信息是什么


找到问题了,原来是这几个的顺序错了,把D防止最前面,然后是C,再次的B,再次是A