主页 > 知识库 > 解决laravel查询构造器中的别名问题

解决laravel查询构造器中的别名问题

热门标签:服务器配置 Linux服务器 科大讯飞语音识别系统 阿里云 Mysql连接数设置 银行业务 电子围栏 团购网站

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语句是什么样的。我们用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()。

您可能感兴趣的文章:
  • Laravel框架DB facade数据库操作详解
  • Laravel5.7 数据库操作迁移的实现方法
  • PHP开发框架Laravel数据库操作方法总结
  • Laravel5中实现模糊匹配加多条件查询功能的方法
  • laravel技巧之查询构造器Query Builder叠加链式调用的方法
  • 使用Laravel中的查询构造器实现增删改查功能
  • Laravel 5框架学习之Eloquent (laravel 的ORM)
  • 详解PHP的Laravel框架中Eloquent对象关系映射使用
  • Laravel 5框架学习之Eloquent 关系
  • Laravel Eloquent ORM 实现查询表中指定的字段
  • Laravel5.7 Eloquent ORM快速入门详解
  • laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析

标签:衡水 江苏 广元 大理 衢州 蚌埠 枣庄 萍乡

巨人网络通讯声明:本文标题《解决laravel查询构造器中的别名问题》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266