Laravel如何操作JSON类型的数据库字段?(Eloquent示例)

admin 百科 12
Laravel通过$casts自动处理JSON字段的序列化与反序列化,支持array/object/collection类型;需用数据库原生JSON函数(如JSON_SET)实现局部更新;提供whereJsonContains、whereJsonLength等查询方法适配多数据库;可配合访问器/修改器定制逻辑。

Laravel如何操作JSON类型的数据库字段?(Eloquent示例)-第1张图片-佛山资讯网

在 Laravel 中操作 JSON 类型字段(如 MySQL 5.7+ 的 JSON 类型、PostgreSQL 的 jsonb 或 SQLite 的文本模拟),Eloquent 提供了原生支持,无需手动序列化/反序列化。关键在于正确设置模型属性和使用访问器、修改器或直接查询语法。

1. 模型中声明 JSON 字段为数组/对象类型

Laravel 会自动将 JSON 字段转为 PHP 数组(或 StdClass 对象),前提是该字段被标记为 $casts 中的 'array''object''collection'

class User extends Model
{
    protected $casts = [
        'preferences' => 'array', // 存储为 JSON,读取为关联数组
        'settings'    => 'object', // 读取为 StdClass 实例
        'tags'        => 'collection', // 自动转为 Illuminate\Support\Collection
    ];
}

登录后复制

这样写入时传数组,Laravel 自动 json_encode;读取时自动 json_decode,无需手动处理。

2. 写入和更新 JSON 字段(整体或局部)

整体更新直接赋值即可:

  • 整字段替换:$user->preferences = ['theme' => 'dark', 'notifications' => true]; $user->save();
  • 局部更新(MySQL 5.7+):DB::raw() 或 Eloquent 的 whereJsonContains/whereJsonLength 等方法,但「局部更新」需用原生 JSON 函数:

// 更新 preferences.theme 而不覆盖整个字段(MySQL)
DB::table('users')
    ->where('id', 1)
    ->update([
        'preferences' => DB::raw("JSON_SET(preferences, '$.theme', 'light')")
    ]);

// 或用模型:$user->update(['preferences' => DB::raw("JSON_SET(...)")]);

登录后复制

注意:Eloquent 默认不支持「只改 JSON 内某个键」的语法糖,必须借助数据库原生 JSON 函数。

3. 查询 JSON 字段(条件检索)

Laravel 支持多种 JSON 查询语法,适配不同数据库:

标签: mysql php laravel js json ai 修改器

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~