Laravel 5.3 查询构建器方法 where/update 新增 JSON 属性操作语法


从 5.0 版本起 Laravel 就支持 JSON 格式数据的转换,之前这样做的目的只是为了方便业务处理,数据存储在数据库的数据类型依然是 TEXT,但是 MySQL 5.7 版本起开始支持原生的 JSON 数据类型,这将为我们的开发带来极大方便。Laravel 5.3 也为基于 JSON 类型的数据查询和更新引入了新的语法。

假设我们有一个包含 JSON 类型字段的数据表:

class CreateContactsTable extends Migration
{
    public function up()
    {
        Schema::create('contacts', function (Blueprint $table) {
            $table->increments('id');
            $table->string('name');
            $table->json('meta');
            $table->timestamps();
        });
    }
    ...
}

我们假设每个联系表单都包含一些基本功能信息,比如联系人姓名,但是另外的一些属性是很灵活的,存储这种类型信息的最好方式就是 JSON 类型 —— 就像上面的 meta 字段。

假定某个联系表单信息如下:

{
    "id": 1,
    "name": "Alphonse",
    "meta": {
        "wants_newsletter": true,
        "favorite_color": "red"
    }
}

现在我们想要获取所有favorite_colorred的用户,在 Laravel 5.3 中我们可以这么做:

$redLovers = DB::table('contacts')
    ->where('meta->favorite_color', 'red')
    ->get();

这段代码将会从contacts表中把meta字段的favorite_color属性值为red的所有记录取出来。

如果想要更新meta字段属性可以这么做:

DB::table('contacts')
    ->where('id', 1)
    ->update(['meta->wants_newsletter' => false]);

即使wants_newsletter键值之前为空,现在也会被设置为false

神奇吧,在 Laravel 5.3 中我们可以基于JSON字段的属性进行查询和更新,而不需要去写那些枯燥重复的处理代码。

注:目前只有 MySQL 5.7+ 支持这一特性。

点赞 取消点赞 收藏 取消收藏

<< 上一篇: Laravel 5.3 起将使用 Vue.js 作为默认 JavaScript 前端框架

>> 下一篇: Laravel 5.3 新增全局辅助函数 cache() 用法一览