0

0

将原生 SQL 查询转换为 Laravel Eloquent 查询的完整指南

聖光之護

聖光之護

发布时间:2025-12-31 17:45:42

|

860人浏览过

|

来源于php中文网

原创

将原生 SQL 查询转换为 Laravel Eloquent 查询的完整指南

本文详解如何将统计“过去 30 天每日浏览量”的原生 sql 转换为 laravel 的 query builder 写法,涵盖日期截取、分组聚合、排序限制等关键点,并指出常见陷阱与最佳实践。

在 Laravel 中,直接使用 DB::table()(即 Query Builder)是处理此类聚合查询最清晰、高效的方式——相比强行套用 Eloquent 模型,它更贴近 SQL 语义,且避免了模型层不必要的开销。

但需注意:您提供的原始答案中存在严重语法错误,会导致查询失败或结果异常。例如:

  • ❌ "date ('created_at')" —— 错误的字符串拼接,date() 是 MySQL 函数,不能加引号;
  • ❌ groupBy("created_at") —— 按完整时间戳分组 ≠ 按日期分组,将导致每天多条记录(因 created_at 含时分秒);
  • ❌ orderBy("created_at","desc") —— 应按日期排序,而非带精度的时间戳,否则分组后排序逻辑错乱;
  • ❌ 缺少 DATE() 函数的正确用法及数据库兼容性处理。

✅ 正确写法(兼容 MySQL)如下:

use Illuminate\Support\Facades\DB;

$viewsByDay = DB::table('views')
    ->selectRaw('DATE(created_at) as day, COUNT(*) as titles')
    ->where('view_type', 'App\\Title')
    ->groupBy('day') // 按别名分组(MySQL 支持),或改用 selectRaw 中的表达式
    ->orderBy('day', 'desc')
    ->limit(30)
    ->get();

? 关键说明:

稿定AI绘图
稿定AI绘图

稿定推出的AI绘画工具

下载
  • selectRaw() 用于注入原生 SQL 表达式,DATE(created_at) 精确提取日期部分(如 '2024-05-20');
  • groupBy('day') 利用 MySQL 对 SELECT 别名的支持,简洁安全;若需跨数据库兼容(如 PostgreSQL),应改为 groupBy(DB::raw('DATE(created_at)'));
  • orderBy('day', 'desc') 确保按自然日期倒序排列(最新日优先);
  • limit(30) 控制返回条数,符合需求。

? 进阶建议:

  • 若项目已定义 View 模型,可配合 toBase() 获取查询构造器,但无实质优势;
  • 需补全时间范围(如近 30 天内有数据才显示)?可追加 whereBetween('created_at', [now()->subDays(30), now()]);
  • 返回结果中 day 是字符串,如需 Carbon 实例,可在集合中映射转换:->map(fn ($item) => tap($item, fn ($i) => $i->day = \Carbon\Carbon::parse($i->day)))。

总结:Query Builder 是处理复杂聚合查询的首选工具。牢记 selectRaw + groupBy + orderBy 的协同逻辑,避开字符串误引、分组粒度错误等典型坑,即可精准复现原生 SQL 语义。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

313

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

270

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

363

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

363

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

80

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

63

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

62

2025.08.05

数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

674

2023.10.12

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 777人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号