zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    洛谷 P1525 关押罪犯(并查集|二分图判定&二分答案)
    洛谷 P1948 [USACO08JAN]Telephone Lines S(贪心+最短路)
    洛谷 P1315 观光公交(贪心+模拟)
    洛谷 P3258 [JLOI2014]松鼠的新家(树上差分)
    【NOIP2001】统计单词个数
    【洛谷习题】皇后游戏
    【洛谷习题】木棍加工
    【SDOI2008】仪仗队
    【洛谷习题】末日的传说
    【洛谷习题】又是毕业季I
  • 原文地址:https://www.cnblogs.com/lxwphp/p/10669353.html
Copyright © 2011-2022 走看看