教程集 www.jiaochengji.com
教程集 >  脚本编程  >  php  >  正文 Laravel 5.3 查询构建器方法 where/update 新增 JSON 属性操作语法

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

发布时间:2017-12-09   编辑:jiaochengji.com
教程集为您提供Laravel 5.3 查询构建器方法 where/update 新增 JSON 属性操作语法等资源,欢迎您收藏本站,我们将为您提供最新的Laravel 5.3 查询构建器方法 where/update 新增 JSON 属性操作语法资源
下面我们来看一篇关于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 支持这一特性。

您可能感兴趣的文章:
Laravel 5.3 查询构建器方法 where/update 新增 JSON 属性操作语法
Laravel 5.2 数据库查询的例子
搭建php Laravel框架教程详解
Laravel 5.2数据库安装配置及简单例子
swoole laravel 区别
Laravel 5.1 中的ACL用户授权及权限检查功能例子
PHP面试题大全(值得收藏)
Laravel 5.3 新特性Laravel Echo 使用:实时聊天室
设计高效合理的MySQL查询语句的建议
mysql select语句同时UPDATE同一张表的方法举例

[关闭]
~ ~