从品牌网站建设到网络营销策划,从策略到执行的一站式服务
这篇文章给大家分享的是有关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语句就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图