• Laravel Eloquent ORM 时如何查询表中指定的字段


    导读:在使用Laravel ORM的Model方法find, get, first方法获取数据对象时返回的数据对象的attributes属性数组里会包含数据表中所有的字段对应...原文地址:http://www.bcty365.com/content-153-5939-1.html

    在使用Laravel ORM的Model方法find, get, first方法获取数据对象时返回的数据对象的attributes属性数组里会包含数据表中所有的字段对应的键值关系, 那么如何在ORM查询时只返回数据表中指定字段的数据呢?很多时候,文档上没有写明的用法需要我们去看源码来探究的,下面我们就来看一下这三个方法的实现。

    由于ORM依赖了QueryBuilder来实现查询, 在QueryBuilder的源码里通过查看get,first方法的实现可以到,他们都可以接收一个数组参数来指定要查询的字段:

    find方法的实现是在IlluminateDatabaseEloquentBuilder类里,如下:

    /** 
     * Find a model by its primary key. 
     *www.bcty365.com  
     * @param  mixed  $id 
     * @param  array  $columns 
     * @return IlluminateDatabaseEloquentModel|IlluminateDatabaseEloquentCollection|null 
     */ 
    public function find($id, $columns = ['*']) 
    { 
        if (is_array($id)) { 
            return $this->findMany($id, $columns); 
        } 
     
        $this->query->where($this->model->getQualifiedKeyName(), '=', $id); 
     
        return $this->first($columns); 
    } 

    由于Eloquent Query Builder是依赖查询构建器IlluminateDatabaseQueryBuilder的,first和get方法的源码在Query Builder里如下:

    /** 
     * Execute the query and get the first result. 
     * 
     * @param  array   $columns 
     * @return mixed|static 
     */ 
    public function first($columns = ['*']) 
    { 
        $results = $this->take(1)->get($columns); 
     
        return count($results) > 0 ? reset($results) : null; 
    } 
     
    /** 
     * Execute the query as a "select" statement. 
     * 
     * @param  array  $columns 
     * @return array|static[] 
     */ 
    public function get($columns = ['*']) 
    { 
        if (is_null($this->columns)) { 
            $this->columns = $columns; 
        } 
     
        return $this->processor->processSelect($this, $this->runSelect()); 
    } 

    所以使用Laravel的ORM方法查询返回指定的字段可通过如下三种方法来实现

    $data = ModelA::find($id, ['column1', 'column2']); 
     
    $data = ModelA::first(['column1', 'column2']); 
     
    $data = ModelA::where(['column1', '=', 'value'])->get(['column1', 'column2']); 

    在不同的场景下三者中选符合需要的使用即可。

    转载: http://www.bcty365.com/content-153-5939-1.htm

  • 相关阅读:
    致 CODING 用户的元宵问候
    持续集成之理论篇
    基于 CODING 的 Spring Boot 持续集成项目
    使用 CODING 进行 Hexo 项目的持续集成
    使用 CODING 进行 Spring Boot 项目的集成
    三种前端模块化规范
    XSS和CSRF
    小问题填坑,关于obj.x和obj["x"]
    说一个闭包在实际开发中的应用
    关于return的分号自动插入问题
  • 原文地址:https://www.cnblogs.com/lxwphp/p/10669353.html
Copyright © 2020-2023  润新知