如下语句:
$tdb = M();
$info = $tdb->table(array('w_master'=>'A','w_detail'=>'B'))->where(array('A.id'=>'B.q_id','B.is_del'=>'0','A.id'=>'1','A.pid'=>'1'))->order('B.sorts')->buildSql();
echo $info;
你会发现的sql语句如下:( SELECT * FROM `w_master` `A`,`w_detail` `B` WHERE B.is_del = '0' AND A.id = '1' AND A.pid = '1' ORDER BY B.sorts ),我想生成的语句是:
( SELECT * FROM `w_master` `A`,`w_detail` `B` WHERE A.id=B.q_id AND B.is_del = '0' AND A.id = '1' AND A.pid = '1' ORDER BY B.sorts )
当把where条件换成字符串就好了,不知道这种多表查询在不使用join的情况下,如何使用where数组来生成sql?
即便使用表的全名,第一个条件也会变成w_master='w_detail.q_id',即等号右边会强制加上引号变成字符串
仔细翻阅了手册,最终还是用数组来实现的,实现的方法是用exp参数,代码如下:
$tdb = M();
$info = $tdb->table(array('w_master'=>'A','w_detail'=>'B'))->where(array(
'B.q_id'=>array('exp','= A.id'),
'B.is_del'=>'0',
'A.id'=>'1',
'A.pid'=>'1'
))->order('B.sorts')->buildSql();
echo $info;
如果你够仔细,你会发现where条件的第一个数组为什么把B.q_id写到前面了,原因是:thinkphp可能会自动优化查询条件(暂且叫做优化吧,因为ThinkPHP在解析时会就是在给条件数组赋值,第一次时候arr['A.id']='1',第二次arr['A.id']='2',那肯定只保留第二次的值了),比如一个条件是这样的:A.id=B.q_id and A.id=1,thinkphp会自动删除第一个A.id=B.q_id的条件,最终变成A.id=1,表面上看起来是优化,但实际上在多表关联条件查询时这个明显是不合适的,解决方法是写成B.q_id=A.id and A.id=1 最佳答案
