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

  • 相关阅读:
    2019年----沉淀的一年
    条目八《永不建立auto_ptr的容器》
    条目七《如果容器中包含了通过new操作创建的指针,切记在容器对象析构前将指针delete掉》
    条目六《当心C++编译器中最烦人的分析机制》
    条目五《尽量使用区间成员函数代替它们的单元素兄弟》
    cpu上下文切换
    条目四《用empty来代替检查size()是否为0》
    条目三《确保容器中的副本对象高效而正确》
    ORB与LBP、HOG
    C++
  • 原文地址:https://www.cnblogs.com/lxwphp/p/10669353.html
Copyright © 2011-2022 走看看