plays()->where('plays.created_at', '>=','DATE(now()) - i-6ren">
gpt4 book ai didi

php - Eloquent - "where"没有引号出现在 SQL 中并破坏它怎么办?

转载 作者:行者123 更新时间:2023-11-29 07:39:01 25 4
gpt4 key购买 nike

这是 Laravel 代码:

$plays_in_period = $partner->plays()->where('plays.created_at', '>=','DATE(now()) - interval '.$periodDays.' day')->count();

这是生成的 SQL:

select count(*) as aggregate 
from `plays` inner join `promotion` on `promotion`.`id` = `plays`.`promotion_id`
where `promotion`.`partner_id` = 1
and `plays`.`created_at` >= 'DATE(now()) - interval 100 day'

注意 'DATE(now()) - interval 100 day' 周围的引号。

这是语法错误,应该是:

select count(*) as aggregate 
from `plays`
inner join `promotion` on `promotion`.`id` = `plays`.`promotion_id` where `promotion`.`partner_id` = 1
and `plays`.`created_at` >= date(now()) - interval 100 day

有什么想法可以让我 Eloquent 地放弃最后日期部分周围的引号以便执行吗?

我特别需要在数据库中使用 now(),因为我希望它与数据库时区设置相关,而不是当前客户端使用的任何内容,因此使用 Carbon 等。 , 不是一个选项。

最佳答案

我们需要使用 DB::raw() helper 传递原始查询段:

$query->where('plays.created_at', '>=', DB::raw('DATE(NOW()) - INTERVAL ' . $periodDays . ' DAY'))...

这会创建一个 expression 对象,Laravel 不会用引号引起来。或者,我们可以使用查询生成器的 whereRaw() 方法:

$query->whereRaw('plays.created_at >= DATE(NOW()) - INTERVAL ? DAY', [ $periodDays ])...

whereRaw() 方法允许我们将参数绑定(bind)到原始查询以避免 SQL 注入(inject)攻击。

关于php - Eloquent - "where"没有引号出现在 SQL 中并破坏它怎么办?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47424297/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com