Mey*_*sam 4 php mysql parameterbinding laravel octobercms
我有以下原始查询:
$results = Db::select( Db::raw("SELECT HOUR(created_at) as hour, COUNT(*) as count
FROM `visited`
WHERE created_at >= DATE_SUB(NOW(),INTERVAL 16 DAY)
GROUP BY HOUR(created_at)") );
Run Code Online (Sandbox Code Playgroud)
我需要参数化日间隔,所以我尝试了这个:
$days = 16;
$results = Db::select( Db::raw("SELECT HOUR(created_at) as hour, COUNT(*) as count
FROM `visited`
WHERE created_at >= DATE_SUB(NOW(),INTERVAL :days DAY)
GROUP BY HOUR(created_at)", ["days" => $days]) );
Run Code Online (Sandbox Code Playgroud)
但是我收到以下错误:
"SQLSTATE [HY000]:一般错误:2031
显然绑定不起作用.我究竟做错了什么?
试试这个:
$results = DB::select('SELECT HOUR(created_at) as hour, COUNT(*) as count FROM visited WHERE created_at >= DATE_SUB(NOW(),INTERVAL ? DAY) GROUP BY HOUR(created_at)', [16]);
Run Code Online (Sandbox Code Playgroud)
您甚至可以使用命名绑定:
$results = DB::select('SELECT HOUR(created_at) as hour, COUNT(*) as count FROM visited WHERE created_at >= DATE_SUB(NOW(),INTERVAL :days DAY) GROUP BY HOUR(created_at)', ['days' => 16]);
Run Code Online (Sandbox Code Playgroud)
不需要使用DB::raw(),只需DB::select()用于简单的原始选择查询:https://laravel.com/docs/master/database#running-queries
| 归档时间: |
|
| 查看次数: |
8368 次 |
| 最近记录: |