Laravel通过->操作符和$casts实现JSON字段的便捷查询与更新,支持条件筛选、字段提取、嵌套查询及whereJsonContains等高级用法,结合访问器与修改器可安全处理结构化数据。

在Laravel中操作数据库的JSON字段变得越来越常见,尤其是在需要灵活存储结构化数据的场景下。MySQL 5.7+ 和 PostgreSQL 等主流数据库都支持原生JSON类型,Laravel通过Eloquent和查询构造器提供了便捷的方式来查询和更新这些字段。
如何查询JSON字段
Laravel允许你使用->操作符来访问JSON字段中的值,这在where、select、orderBy等语句中都非常实用。
基本语法:
`users` 表有一个 `profile` JSON字段,内容如:{"age": 25, "city": "Beijing"}- 查询 profile 中 age 等于 25 的用户:
User::where('profile->age', 25)->get(); - 模糊匹配 city 字段:
User::where('profile->city', 'like', '%jing%')->get(); - 嵌套JSON查询(如 profile 包含 {"address": {"district": "Haidian"}}):
User::where('profile->address->district', 'Haidian')->get();
你也可以在 select 中提取JSON字段:
User::select('id', 'profile->city as city')->get();
如何更新JSON字段
Laravel会自动识别模型中定义为数组的属性,并将其序列化为JSON写入数据库。你可以在模型中配合 $casts 来实现自动转换。
标签: mysql php laravel js json access ai 数据清洗 json数组 修改器
还木有评论哦,快来抢沙发吧~