解析Laravel框架下的Contracts契约_laravel框架
Laravel 的契约是一组定义框架提供的核心服务的接口, 例如我们在介绍用户认证的章节中到的用户看守器契约IllumninateContractsAuthGuard 和用户提供器契约......
默认情况下,toSql 获取到的 sql 里面的参数使用 "?" 代替的,如下:
DB::table('user')->where('id', 1)->toSql();
获取到的 sql 语句是:
select * from `tb_user` where `id` = ?
有时候我们想要得到具体的语句,可以利用 builder 的 getBindings 方法:
Laravel实现跟踪用户是否在线功能_laravel框架
Laravel 中使用简单的方法跟踪用户是否在线:今天,我的任务是,在 Laravel 应用程序用户个人资料页面上,用户名旁边添加一个绿点,表示他们是否在线。我首先想到的是,我们将需要启动一个 node.js 服务器并跟踪每个用户....
$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框架相关技术文章,请访问laravel教程栏目!
以上就是laravel中的toSql如何获取带参数的sql语句的详细内容,更多请关注ki4网其它相关文章!
Laravel 6.2中用于用户登录的新密码确认流程(代码实例)_laravel框架
Laravel 发布了 v6.2 版本,它添加了一个新的密码确认功能,该功能使你可以要求已登录的用户重新输入密码,然后才能访问路由。