Laravel 5.2 - pluck() 方法返回数组

Posted

技术标签:

【中文标题】Laravel 5.2 - pluck() 方法返回数组【英文标题】:Laravel 5.2 - pluck() method returns array 【发布时间】:2016-03-28 02:03:32 【问题描述】:

我正在尝试升级我的项目 L5.1 -> L5.2。在upgrade guide 中,我不清楚一件事:

集合、查询构建器和 Eloquent 查询上的 lists 方法 构建器对象已重命名为 pluck。方法签名 保持不变。

没关系,将重构从 lists() 重命名为 pluck() 不是问题。但是 L5.0 和 L5.1 中有用的 pluck() 方法呢?

来自5.0 documentation:

从一行中检索单个列

$name = DB::table('users')->where('name', 'John')->pluck('name');

L5.2 中旧的pluck() 方法的替代方法是什么?

更新:

例子:

var_dump(DB::table('users')->where('id', 1)->pluck('id'));

L5.1:

// int(1)

L5.2:

// array(1)  [0]=> int(1) 

【问题讨论】:

是的,这很令人困惑。在 5.0 中,pluck() 表示从一行中选择 1 个字段。然后在 5.1 中,他们删除了 pluck() 并将其替换为 value()。然后在 5.2 中,他们将返回整列的 lists() 替换为 pluck()。因此,如果您从 4.2 开始就一直存在,您可能会感到困惑:/ 【参考方案1】:

我使用 laravel 7.x 并以此作为解决方法:->get()->pluck('id')->toArray();

它返回一个 ID 数组 [50,2,3],这是我使用的整个查询:

   $article_tags = DB::table('tags')
    ->join('taggables', function ($join) use ($id) 
        $join->on('tags.id', '=', 'taggables.tag_id');
        $join->where([
            ['taggable_id', '=', $id],
            ['taggable_type','=','article']
        ]);
    )->select('tags.id')->get()->pluck('id')->toArray();

【讨论】:

AModel::select('id',...)->where(...)->get()->pluck('id'); 给出id 的整数值数组,当AModel::select('id',...)->where(...)->get()->pluck('id')->toArray(); 给出类似[0=>id0, 1=>id1,...., n=>idN] 的数组时,已测试。【参考方案2】:

laravel pluck 返回一个数组

如果您的查询是:

 $name = DB::table('users')->where('name', 'John')->pluck('name');

那么数组是这样的(key是item的索引。自增值):

[
    1 => "name1",
    2 => "name2",
    .
    .
    .
    100 => "name100"
]

但如果你这样做:

$name = DB::table('users')->where('name', 'John')->pluck('name','id');

那么关键是数据库中的实际索引。

key||value
[
    1 => "name1",
    2 => "name2",
    .
    .
    .
    100 => "name100"
]

您可以将任何值设置为键。

【讨论】:

【参考方案3】:

在 Laravel 5.1+ 中,你可以使用 value() 代替 pluck。

要获得第一次出现,您可以使用

DB::table('users')->value('name');

或使用,

DB::table('users')->where('id', 1)->pluck('name')->first();

【讨论】:

【参考方案4】:

在原始示例中,为什么不在数据库查询中使用 select() 方法?

$name = DB::table('users')->where('name', 'John')->select("id");

这将比使用 php 框架更快,因为它将利用 SQL 查询为您进行行选择。对于普通的集合,我认为这并不适用,但是由于您使用的是数据库...

Larvel 5.3:Specifying a Select Clause

【讨论】:

需要添加->get();你仍然需要使用 PHP 来格式化数组 php操作比mysql查询快很多。 @AnkitBalyan 你在讽刺吗? mysql 比 php 快得多。尝试在每个中处理一百万行...【参考方案5】:

pluck() 的当前替代方案是 value()

【讨论】:

谢谢!这绝对应该在升级指南中,因为它是重大变化。 我看到它在 5.1 的升级指南中:laravel.com/docs/5.2/upgrade#upgrade-5.1.0 很遗憾,我在上一个版本中没有发现这个变化。 实际上有关于此更改的通知:“Eloquent 集合实例现在为以下方法返回一个基本集合 (Illuminate\Support\Collection):pluck, ...” 值的使用要容易得多,因为它是现成的非数组形式。尤其是在切换类型操作中 @user1669496 谢谢先生

以上是关于Laravel 5.2 - pluck() 方法返回数组的主要内容,如果未能解决你的问题,请参考以下文章

采摘渴望加载Laravel 5.2

关于 Laravel 5.7 中 Pluck 结果的问题

laravel的pluck用法

在 Laravel 5.4 的查询生成器中添加 lists() 方法

Laravel 5.2 - 方法身份验证不存在

Laravel 5.2 无法将跨域 jQuery 方法识别为 AJAX