新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章给大家分享的是有关laravel中的toSql怎么获取带参数的sql语句的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。
创新互联建站专注于新乡县网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供新乡县营销型网站建设,新乡县网站制作、新乡县网页设计、新乡县网站官网定制、成都小程序开发服务,打造新乡县网络公司原创品牌,更为您提供新乡县网站排名全网营销落地服务。
默认情况下,toSql 获取到的 sql 里面的参数使用 "?" 代替的,如下:
DB::table('user')->where('id', 1)->toSql();
获取到的 sql 语句是:
select * from `tb_user` where `id` = ?
有时候我们想要得到具体的语句,可以利用 builder 的 getBindings 方法:
$builder = DB::table('user')->where('id', 1); $bindings = $builder->getBindings(); $sql = str_replace('?', '%s', $builder->toSql()); $sql = sprintf($sql, ...$bindings); dd($sql);
获取到的 sql 语句是:
select * from `tb_user` where `id` = 1
如果经常使用可以考虑使用 Builder 的 macro 方法加进 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());
感谢各位的阅读!关于laravel中的toSql怎么获取带参数的sql语句就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!