By default, the parameters in the sql obtained by toSql are replaced by "?", as follows:
DB::table('user')->where('id', 1)->toSql();
The sql statement obtained is:
select * from `tb_user` where `id` = ?
Sometimes we want to get specific statements, we can use the builder's getBindings method:
$builder = DB::table('user')->where('id', 1); $bindings = $builder->getBindings(); $sql = str_replace('?', '%s', $builder->toSql()); $sql = sprintf($sql, ...$bindings); dd($sql);
The obtained sql statement is:
select * from `tb_user` where `id` = 1
If you use it frequently, you can consider using the Builder The macro method is added to the Builder:
\Illuminate\Database\Query\Builder::macro('sql', function () { $bindings = $this->getBindings(); $sql = str_replace('?', '%s', $this->toSql()); return sprintf($sql, ...$bindings); }); dd(DB::table('user')->where('id', 1)->sql());
For more technical articles related to the laravel framework, please visit the laravel tutorial column!
The above is the detailed content of How to get the sql statement with parameters using toSql in laravel. For more information, please follow other related articles on the PHP Chinese website!