容易产生错误的where条件

错误的方式:
$where = [];
if ($type == 'wait') {
$where['status'] = 0;
}
if ($type == 'done') {
$where['status'] = ['exp', '=1 or status = 2'];
}
$where['employee_id'] = $id;

return DB::M()
->table(self::TABLE)
->where($where)
->order('add_time desc')
->select();


SQL:
1:SELECT * FROM oa_employee_bill WHERE `status`='0' AND `employee_id`='4' ORDER BY add_time desc [Exec:0.00058984756469727s]
2:SELECT * FROM oa_employee_bill  WHERE  `employee_id`='4'  ORDER BY add_time desc [Exec:0.00065398216247559s]
3:SELECT * FROM oa_employee_bill  WHERE  `status`  =1 or status = 2 AND `employee_id`='4'  ORDER BY add_time desc [Exec:0.00068211555480957s]
WHERE  (`status`  =1 )or (status = 2 AND `employee_id`='4') 

正确的方式:
$where = [];
if ($type == 'wait') {
$where['status'] = 0;
}
if ($type == 'done') {
$where['status'] = ['exp', '>0 and status < 3'];
}
$where['employee_id'] = $id;

return DB::M()
->table(self::TABLE)
->where($where)
->order('add_time desc')
->select();

SQL:
1: SELECT * FROM oa_employee_bill  WHERE  `employee_id`='4'  ORDER BY add_time desc [Exec:0.00057578086853027s]
2: SELECT * FROM oa_employee_bill  WHERE  `status`='0' AND `employee_id`='4'  ORDER BY add_time desc [Exec:0.00056815147399902s]
3: SELECT * FROM oa_employee_bill  WHERE  `status`  >0 and status < 3 AND `employee_id`='4'  ORDER BY add_time desc [Exec:0.00062203407287598s]
 WHERE  `status`  >0 and status < 3 AND `employee_id`='4' 只是一个情况


转载于:https://www.cnblogs.com/Cxymds/p/5329136.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值