4


我知道 Laravel 已删除lists()函数并将函数签名移动为pluck(). 但是,对于想要从Laravel 4.x 升级到 Laravel 5.4的人来说,这会导致很多工作。

因此,我试图找到一种方法来利用现有函数,即lists()在我的代码中,并在pluck()->toArray()调用该函数时利用它。


我尝试了以下方法。

方法一

class BaseModel extends  Illuminate\Database\Query\Builder
public function __call($method, $args)
{
    return call_user_func_array($this->method,$args);
}

public function lists($column){
return $this->pluck($column)->toArray();
}

不会工作!
原因:这需要与 BaseModel 类一起扩展。但是,它已经扩展了 Eloquent 模型类。

方法二

trait尝试使用like添加所需的功能

列表WorkAround.php

<?php
trait listsWorkAround
{ 
  function lists($column){
    return $this->pluck($column)->toArray();
  }
}

模型.php

<?php
namespace App;

use Watson\Rememberable\Rememberable;
use Illuminate\Database\Eloquent\Model as Eloquent;

abstract class Model extends Eloquent
{
    use listsWorkAround;
    use Rememberable;
}

不,不是没有成功。

方法三

尝试添加一个 as并为ClassServiceProvider添加一个macro函数,即在这种情况下。 但是,问题是最终返回的实体是一个集合,因为它是使用Builder 的函数返回的。但是,所需的实体是.Builderlists
__callArray

编辑:我用于方法 3 的代码

<?php
namespace Providers;
use Illuminate\Database\Query\Builder;
use Illuminate\Support\ServiceProvider;

class ListsWorkAround extends ServiceProvider
{
    /**
     * {@inheritdoc}
     */
    public function register()
    {
        Builder::macro("lists", function ($column) {        
            return $this->pluck($column)->toArray();
        });
    }
}

但是,正如我所说,这仍然会返回 Collection。

4

2 回答 2

8

所以,这就是我最终要让它发挥作用的方法lists(),即Model::XXX->lists()

在..../config/app.php 中添加了这个

'providers' => [
 ...
 ...
 \App\Providers\ListsWorkAround::class,
],

这是提供者类文件。

ListsWorkAround.php

<?php
/**
 * Created by PhpStorm.
 * User: ateeq-ahmed
 * Date: 14/4/17
 * Time: 11:25 AM
 */

namespace App\Providers;

use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Query\Builder as QueryBuilder;
use Illuminate\Support\ServiceProvider;

class ListsWorkAround extends ServiceProvider
{
    /**
     * {@inheritdoc}
     */
    public function register()
    {
        Builder::macro("lists", function ($column, $key = null) {
            return $this->pluck($column, $key)->all();
        });

        QueryBuilder::macro("lists", function ($column, $key = null) {
            return $this->pluck($column, $key)->all();
        });
    }
}
于 2017-04-14T06:29:52.543 回答
3

如果你真的想要,你可以宏lists进入查询生成器、雄辩生成器和集合

宏查询生成器:

Illuminate\Database\Query\Builder::macro('lists', function ($column, $key = null) {
    return $this->pluck($column, $key)->all(); 
});


DB::table('users')->lists('email');
于 2017-04-13T16:53:21.150 回答