导读:本期聚焦于小伙伴创作的《Laravel Eloquent 中获取查询构建器已选列的正确方式是什么》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Laravel Eloquent 中获取查询构建器已选列的正确方式是什么》有用,将其分享出去将是对创作者最好的鼓励。

在Laravel的Eloquent查询构建操作中,我们有时会需要获取当前查询构建器已经设置的选中列,用于后续的查询逻辑处理或者调试。由于Laravel的查询构建器并没有对外暴露直接获取已选列的公共API,因此需要借助一些内部属性或者扩展方式来实现。

Laravel Eloquent 中获取查询构建器已选列的正确方式是什么

直接访问查询构建器内部属性

Laravel的查询构建器实例中,选中的列会存储在columns属性中,这个属性是受保护的,但是我们可以通过反射或者直接访问(在部分版本中属性访问权限有调整)来获取值。需要注意的是,这种方式依赖框架内部实现,框架版本升级时可能会有变动。

示例代码如下:

<?php
use AppModelsUser;
use ReflectionProperty;

// 创建查询构建器实例
$query = User::select(['id', 'name', 'email']);

// 使用反射获取受保护的columns属性
$reflection = new ReflectionProperty($query->getQuery(), 'columns');
$reflection->setAccessible(true);
$selectedColumns = $reflection->getValue($query->getQuery());

// 输出已选列
var_dump($selectedColumns);

通过闭包回调获取构建过程中的列

如果是在查询构建的过程中需要获取已选列,我们可以在调用select方法的时候通过闭包记录选中的列,这种方式不依赖框架内部属性,兼容性更好。

示例代码如下:

<?php
use AppModelsUser;

$selectedColumns = [];

$query = User::select(['id', 'name', 'email'])->when(true, function ($q) use (&$selectedColumns) {
    // 获取当前查询的columns属性
    $selectedColumns = $q->getQuery()->columns ?? ['*'];
});

var_dump($selectedColumns);

自定义扩展查询构建器

如果需要频繁获取已选列,推荐自定义扩展查询构建器,添加一个公共方法来获取已选列,避免重复编写反射代码,同时降低框架版本升级带来的影响。

首先创建自定义查询构建器类:

<?php
namespace AppExtensions;

use IlluminateDatabaseQueryBuilder as QueryBuilder;

class CustomQueryBuilder extends QueryBuilder
{
    /**
     * 获取当前查询已选列
     *
     * @return array
     */
    public function getSelectedColumns(): array
    {
        return $this->columns ?? ['*'];
    }
}

然后创建自定义的Eloquent模型基类,让所有模型继承这个基类:

<?php
namespace AppModels;

use AppExtensionsCustomQueryBuilder;
use IlluminateDatabaseEloquentModel;

abstract class BaseModel extends Model
{
    /**
     * 创建新的查询构建器实例
     *
     * @param IlluminateDatabaseQueryBuilder $query
     * @return IlluminateDatabaseEloquentBuilder|static
     */
    public function newEloquentBuilder($query)
    {
        return new IlluminateDatabaseEloquentBuilder(
            new CustomQueryBuilder(
                $query->getConnection(),
                $query->getGrammar(),
                $query->getProcessor()
            )
        );
    }
}

之后在业务模型中继承BaseModel,就可以直接调用getSelectedColumns方法:

<?php
namespace AppModels;

use AppModelsBaseModel;

class User extends BaseModel
{
    // 模型定义内容
}

// 使用方式
$query = User::select(['id', 'name']);
$columns = $query->getQuery()->getSelectedColumns();
var_dump($columns);

注意事项

  • 直接访问内部属性的方式依赖框架实现,Laravel版本升级后可能会导致代码失效,不建议在生产环境大量使用。
  • 如果没有调用select方法设置选中列,查询构建器的columns属性默认是null,此时默认会查询所有列,对应的值是['*']。
  • 自定义扩展查询构建器的方式兼容性最好,适合需要频繁获取已选列的场景。

LaravelEloquent查询构建器已选列getColumns修改时间:2026-06-14 23:21:14

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。