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_color
为red
的用户,在 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+ 支持这一特性。
7 Comments