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

laravel-5-3-new-features-updates

从 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+ 支持这一特性。

学院君 has written 982 articles

Laravel学院院长,终身学习者

积分:113002 等级:P12 职业:手艺人 城市:杭州

7 条回复

  1. 张鹏 张鹏 says:
    @ jackie 请问,按mysql json格式修改时没问题的,查询时报错是什么原因呢?php 5.6.30 mysql5.7.18
  2. dobest dobest says:
    这个只能使用MySQL5.7以上版本的吧!!!
  3. ___柳青杉 ___柳青杉 says:
    超赞!!之前有个场景就是要用这样的语法,但是之前没有这样的语法,处理起来就非常麻烦了,以后就方便了!
  4. 胖子 胖子 says:
    挺好用的,只不过使用场景不多
  5. 网虫资源网 网虫资源网 says:
    这个好 是不是 使用5.3 mysql也必须要升级到 5.7啊

登录后才能进行评论,立即登录?