laravel中的toSql怎么获取带参数的sql语句

这篇文章给大家分享的是有关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语句就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!


当前名称:laravel中的toSql怎么获取带参数的sql语句
分享URL:http://bzwzjz.com/article/jdijge.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站建设 四川成都网站设计 定制网站设计 成都网站设计 成都网站设计 成都网站建设 成都网站设计公司 自适应网站设计 成都网站制作 泸州网站建设 成都h5网站建设 重庆电商网站建设 手机网站制作 响应式网站设计 成都定制网站建设 移动手机网站制作 成都网站建设 app网站建设 网站设计 网站设计公司 成都网站设计 成都网站设计