解决 thinkphp left join 临时表

如何解决thinkphp left join 遇到右边要提前筛选的情况

比如下面的sql

$map_message['tab_sdk_message.game_id']=$user['game_id'];
$map_message['tab_sdk_message.reach_money']=array('lt',$sum_pay_amount);

$sql=M('sdk_message','tab_')->field('tab_sdk_message.id,tab_sdk_message.content,tab_sdk_message.game_id,tab_sdk_message.creat_time,tab_sdk_message.title,tab_message_read.user_id')->join('LEFT JOIN tab_message_read on tab_sdk_message.id=tab_message_read.article_id')->where($map_message)->order('id desc')->select();

但这个时候我们需要把tab_message_read这张先通过条件筛选一遍。那怎么解决呢。
其实我们可以先通过fetchSql打印出原生sql,然后通过正则把"LEFT JOIN tab_message_read"替换,再用query()方法执行。

完整示例:

 $map_message['tab_sdk_message.game_id']=$user['game_id'];
 $map_message['tab_sdk_message.reach_money']=array('lt',$sum_pay_amount);

 $sql=M('sdk_message','tab_')->field('tab_sdk_message.id,tab_sdk_message.content,tab_sdk_message.game_id,tab_sdk_message.creat_time,tab_sdk_message.title,tab_message_read.user_id')->join('LEFT JOIN tab_message_read on tab_sdk_message.id=tab_message_read.article_id')->where($map_message)->order('id desc')->fetchSql(true)->select();
 $sql1="left join (select * from tab_message_read where user_id=".$user['user_id'].") as tab_message_read";
 $str=preg_replace("/LEFT JOIN tab_message_read/",$sql1,$sql);
 $data=M()->query($str);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值