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