lavavel 中操作数据库查找别名
一、总结(点击显示或隐藏总结内容)
一句话总结:
当有表前缀的时候:DB::table ('users as table1')->select (DB::raw ('table1.id'))->get ();
对应 sql 语句:select table1.id from ykttb_users
as table1
没有表前缀的时候可以不用加那个 DB::raw () 方法
1、laravel 中 raw 方法的作用是什么(比如 DB::table ('users as table1')->select (DB::raw ('table1.id'))->get ();)?
执行原生 sql 用的:比如你可以在里面写 sum (a) as a,sum (b) as b
回到顶部
二、laravel 查询构造器中别名的问题
转自或参考:laravel 查询构造器中别名的问题
https://blog.csdn.net/u011771214/article/d...
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 语句是什么样的。我们用 laravel 提供的一个方法 toSql () 去得到 SQL 语句
DB::table('usersas table1')->select('table1.id')->toSql();
结果为:selectykttb_table1
.id
from ykttb_users
as table1
我们发现写 table1.id 时,laravel 框架自动给我们加上了表前缀,很显然,这样的 SQL 语句得不到我们要的结果。
最后的尝试:DB::table ('users as table1')->select (DB::raw ('table1.id'))->get ();
这样写就没错了,用上面的方法来输出 SQL 语句:select table1.id from ykttb_users
as table1
这就是我们想要执行的 SQL 语句。
总结:在 laravel 中,给表起别名,直接写就可以;但在 select 语句中要用到表的别名来得到字段,我们就要在外面套一层 DB::raw (),
本作品采用《CC 协议》,转载必须注明作者和本文链接
推荐文章: