解决laravel查询构造器中的别名问题
Laravel框架对数据库的封装是⽐较完善的,⽤起来也⽐较⽅便。但之前有⼀个问题⼀直困扰着我,就是利⽤laravel作查询时。如果想给表名或是字段名起别名是⽐较⿇烦的事。但翻阅它的⽂档不难发现,它提供了⼀个DB::raw()的⽅法给我们,利⽤这个⽅法,我们就可以轻松的实现对表的重命名。
问题还原:
⼀般的写法:DB::table('users')->select('id','username')->get();
laravel框架下载这样写是⼀点问题没有的。
加别名的写法:DB::table('users as table1')->select('id')->get();
这样写也不会产⽣错误
我们尝试另⼀咱写法:DB::table('users as table1')->select('table1.id')->get();
这样写就报错了,但这种写法我们⼜是不能避免的,如我们要表users表进⾏⾃连接时,就必须要⽤到别名加点的⽅式去得到字段。这样问题就来了。
不着急,我们先看看这句话输出的SQL语句是什么样的。我们⽤laravel提供的⼀个⽅法toSql()去得到SQL语句
DB::table('usersas table1')->select('table1.id')->toSql();
结果为:select`ykttb_table1`.`id` from `ykttb_users` as `table1`
我们发现写table1.id时,laravel框架⾃动给我们加上了表前缀,很显然,这样的SQL语句得不到我们要的结果。
最后的尝试:DB::table('users astable1')->select(DB::raw('table1.id'))->get();
这样写就没错了,⽤上⾯的⽅法来输出SQL语句:select table1.id from `ykttb_users` as `table1`
这就是我们想要执⾏的SQL语句。
总结:在laravel中,给表起别名,直接写就可以;但在select语句中要⽤到表的别名来得到字段,我们就要在外⾯套⼀层DB::raw()。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论