如何解决Laravel查询构造器中别名冲突的问题?
- 内容介绍
- 文章标签
- 相关推荐
本文共计495个文字,预计阅读时间需要2分钟。
Laravel框架对数据库的封装相当完善,使用起来也相对方便。然而,之前遇到一个问题一直困扰着我,那就是使用Laravel进行查询时,给表名或字段取名总是感到烦恼。
Laravel框架对数据库的封装是比较完善的,用起来也比较方便。但之前有一个问题一直困扰着我,就是利用laravel作查询时。如果想给表名或是字段名起别名是比较麻烦的事。但翻阅它的文档不难发现,它提供了一个DB::raw()的方法给我们,利用这个方法,我们就可以轻松的实现对表的重命名。
问题还原:
一般的写法:DB::table('users')->select('id','username')->get();
这样写是一点问题没有的。
加别名的写法:DB::table('users as table1')->select('id')->get();
这样写也不会产生错误
我们尝试另一咱写法:DB::table('users as table1')->select('table1.id')->get();
这样写就报错了,但这种写法我们又是不能避免的,如我们要表users表进行自连接时,就必须要用到别名加点的方式去得到字段。这样问题就来了。
不着急,我们先看看这句话输出的SQL语句是什么样的。
本文共计495个文字,预计阅读时间需要2分钟。
Laravel框架对数据库的封装相当完善,使用起来也相对方便。然而,之前遇到一个问题一直困扰着我,那就是使用Laravel进行查询时,给表名或字段取名总是感到烦恼。
Laravel框架对数据库的封装是比较完善的,用起来也比较方便。但之前有一个问题一直困扰着我,就是利用laravel作查询时。如果想给表名或是字段名起别名是比较麻烦的事。但翻阅它的文档不难发现,它提供了一个DB::raw()的方法给我们,利用这个方法,我们就可以轻松的实现对表的重命名。
问题还原:
一般的写法:DB::table('users')->select('id','username')->get();
这样写是一点问题没有的。
加别名的写法:DB::table('users as table1')->select('id')->get();
这样写也不会产生错误
我们尝试另一咱写法:DB::table('users as table1')->select('table1.id')->get();
这样写就报错了,但这种写法我们又是不能避免的,如我们要表users表进行自连接时,就必须要用到别名加点的方式去得到字段。这样问题就来了。
不着急,我们先看看这句话输出的SQL语句是什么样的。

