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语句
网站链接:http://www.hxwzsj.com/article/jdijge.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 成都营销网站建设 网站建设费用 成都商城网站建设 营销型网站建设 网站制作公司 app网站建设 成都网站制作 成都商城网站建设 企业手机网站建设 成都网站建设推广 重庆企业网站建设 成都网站建设 高端网站设计推广 网站建设 重庆电商网站建设 成都商城网站制作 网站建设方案 成都网站建设公司 成都品牌网站建设 自适应网站设计 定制级高端网站建设 品牌网站建设