whereOr 在5.0和5.1生成的sql不一样。

浏览:365 发布日期:2019/03/22 分类:ThinkPHP5专区 关键字: sql错误
return self::field(true)
            ->where("is_lunar = 0 and DATE_FORMAT(birthday, '%m-%d') between '{$time['solar_start']}' and '{$time['solar_end']}'")
            ->whereOr("is_lunar = 1 and DATE_FORMAT(birthday, '%m-%d') between '{$time['lunar_start']}' and '{$time['lunar_end']}'")
            ->order('id desc')
            ->paginate();
如上查询在5.0下 whereOr 生成的Sql语句是or ,在5.1下生成的是and;这是为何,最终生成的sql见下面。

5.0生成的是or 如下:SELECT `id`,`user_id`,`brand_id`,`card_number`,`member_name`,`tel`,`sex`,`is_lunar`,`birthday`,`job`,`area`,`address`,`score`,`level_id`,`type`,`is_old`,`create_time`,`update_time` FROM `ta_vip_member` WHERE  (  is_lunar = 0 and DATE_FORMAT(birthday, '%m-%d') between '03-22' and '03-22' ) OR (  is_lunar = 1 and DATE_FORMAT(birthday, '%m-%d') between '02-16' and '02-16' ) ORDER BY `id` DESC
5.1.35生成的如下,唯一不同就是or变成了and
SELECT `id`,`user_id`,`brand_id`,`card_number`,`member_name`,`tel`,`sex`,`is_lunar`,`birthday`,`job`,`area`,`address`,`score`,`level_id`,`type`,`is_old`,`create_time`,`update_time` FROM `ta_vip_member` WHERE  ( is_lunar = 0 and DATE_FORMAT(birthday, '%m-%d') between '03-22' and '03-22' )  AND ( is_lunar = 1 and DATE_FORMAT(birthday, '%m-%d') between '02-16' and '02-16' ) ORDER BY `id` DESC
最佳答案
评论( 相关
后面还有条评论,点击查看>>