新闻中心
Lar*el如何操作JSON类型的数据库字段?(Eloquent示例)
Lar*el通过$casts自动处理JSON字段的序列化与反序列化,支持array/object/collection类型;需用数据库原生JSON函数(如JSON_SET)实现局部更新;提供whereJsonContains、whereJsonLength等查询方法适配多数据库;可配合访问器/修改器定制逻辑。

在 Lar*el 中操作 JSON 类型字段(如 MySQL 5.7+ 的 JSON 类型、PostgreSQL 的 jsonb 或 SQLite 的文本模拟),Eloquent 提供了原生支持,无需手动序列化/反序列化。关键在于正确设置模型属性和使用访问器、修改器或直接查询语法。
1. 模型中声明 JSON 字段为数组/对象类型
Lar*el 会自动将 JSON 字段转为 PHP 数组(或 StdClass 对象),前提是该字段被标记为 $casts 中的 'array'、'object' 或 'collection':
class User extends Model
{
protected $casts = [
'preferences' => 'array', // 存储为 JSON,读取为关联数组
'settings' => 'object', // 读取为 StdClass 实例
'tags' => 'collection', // 自动转为 Illuminate\Support\Collection
];
}
这样写入时传数组,Lar*el 自动 json_encode;读取时自动 json_decode,无需手动处理。
2. 写入和更新 JSON 字段(整体或局部)
整体更新直接赋值即可:
-
整字段替换:
$user->preferences = ['theme' => 'dark', 'notifications' => true]; $user->s*e(); -
局部更新(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 字段(条件检索)
Lar*el 支持多种 JSON 查询语法,适配不同数据库:
拾贝
一键同步微信读书所有笔记和划线,并在新标签页回顾
186
查看详情
-
包含某个值(MySQL/PG):
User::whereJsonContains('preferences', ['notifications' => true])->get(); -
指定路径匹配(MySQL):
User::where('preferences->theme', 'dark')->get();(等价于JSON_EXTRACT(preferences, '$.theme')) -
数组长度判断(MySQL):
User::whereJsonLength('tags', '>', 2)->get(); -
PostgreSQL 特有(推荐用
->>获取文本):User::where('settings->language', 'en')->get();
这些方法底层调用对应数据库的 JSON 函数,Lar*el 自动适配方言。
4. 使用访问器/修改器做自定义处理
若需对 JSON 字段做转换逻辑(比如统一添加默认键、过滤敏感字段),可配合 getFooAttribute 和 setFooAttribute:
class User extends Model
{
protected $casts = ['metadata' => 'array'];
// 读取时补充默认值
public function getMetadataAttribute($value)
{
return array_merge(['version' => '1.0'], $value);
}
// 写入时过滤掉非法键
public function setMetadataAttribute($value)
{
$allowed = ['theme', 'locale', 'timezone'];
$this->attributes['metadata'] = array_intersect_key($value, array_flip($allowed));
}
}
注意:修改器中不要调用 $this->metadata = ...,否则会触发无限递归;应直接操作 $this->attributes。
基本上就这些。核心是善用 $casts 做自动转换,结合数据库原生 JSON 函数做高级查询和局部更新,再按需用访问器/修改器增强逻辑。不复杂但容易忽略细节,比如忘记声明 cast 导致存成字符串,或误以为 -> 语法能直接更新子字段。
以上就是Lar*el如何操作JSON类型的数据库字段?(Eloquent示例)的详细内容,更多请关注php中文网其它相关文章!
# php
# laravel
# mysql
# 南昌电子商城网站建设
# 手工diy的营销推广
# seo教程代运营
# 灵寿海外网站推广案例
# 公司搜狗网站首页优化
# 怎样阻止白嫖网站推广呢
# 营销推广平台代理怎么做
# 舞房推广视频素材下载网站
# 邯郸网站建设门户官网
# 了了网网站建设推广
# 自定义
# 中文网
# 相关文章
# 而不
# 并在
# 序列化
# 需用
# 拾贝
# 递归
# 修改器
# ai
# json
# js
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
NRF24L01数据传输深度解析:解决大载荷接收异常与分包策略
win11专注助手在哪 Win11免打扰模式设置与自动化规则【指南】
J*aScript DOM操作:高效清空列表元素的策略与实践
拼多多视频播放卡顿如何处理 拼多多视频播放优化技巧
css卡片内容溢出如何处理_使用overflow隐藏或scroll显示内容
c++中的std::launder有什么实际用途_c++对象生命周期与指针优化
俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问
Lar*el 递归关系中排除指定分支的教程
XML中包含HTML标签导致解析错误? 正确嵌入非XML数据的两种方法
J*aScript中高效管理与清空动态列表:避免循环陷阱
Django模型中自动计算可用余额的实现方法
QQ网页版官方账号入口 QQ网页版网页版登录指南
163邮箱官方主页登录 直达网易邮箱登录核心页面
魅族17怎样用浏览器译外语网页_iPhone魅族17浏览器译外语网页【即时翻译】
PPT平滑切换怎么做 PPT炫酷“平滑”切换动画制作教程【必学】
Golang如何实现微服务鉴权与权限控制_Golang微服务鉴权与权限管理实践
一加Ace 6T实拍样张首次公布!李杰:主摄实力完全看齐4K档性能旗舰
Win10快速启动功能利弊分析 Win10开启或关闭快速启动教程【技巧】
PHP URL参数传递与500错误调试指南
cad如何更改注释性对象的比例_cad注释性比例调整方法
三星GalaxyZFold5怎样在相册制作折叠屏分镜_iPhone三星GalaxyZFold5相册制作折叠屏分镜【创意编辑】
快手赚钱渠道_快手收益来源
Python自定义类排序:解决lambda键值访问TypeError的实践指南
2026春节假期时间安排 2026春节假日查询
Win11截图该按哪些键 Win11截屏完整流程解析【教程】
Excel Power Pivot如何处理XML数据源 构建高级数据模型
京东单号查询入口_京东快递订单追踪入口
windows10怎么查看硬盘序列号_windows10硬盘id查询命令
C++如何实现单例模式_C++设计模式之线程安全的单例写法
Win11怎么关闭触摸屏_Windows 11禁用HID符合标准触摸屏
顺丰快递查询系统 官方正版查询入口
消息称三星明年 2 月正式发布 HBM4,与 SK 海力士同台竞技
HTML长属性值处理:表单action路径优化与代码规范应对
百度浏览器字体显示异常偏小_百度浏览器字体渲染修复方案
Basecamp怎样用留言钉固定重点_Basecamp用留言钉固定重点【重点标记】
如何将一个大型PHP应用拆分为多个Composer包_微服务与模块化架构的Composer实践
LINUX的I/O重定向是什么_深入理解LINUX中 >、>> 与 < 的区别
拼多多赚钱渠道_拼多多收益来源
如何在低配置电脑上搭建轻量级J*a环境_占用更小的环境选择技巧
Spring Boot嵌入式服务器与J*a EE:功能支持深度解析
抖音网页版企业服务中心登录入口_抖音网页版企业登录平台
QQ邮箱官方登录入口_QQ邮箱网页版快捷使用平台
mcjs网页版流畅运行 mcjs低配电脑畅玩入口
J*aScript异步迭代器_j*ascript异步遍历
邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧
qq游戏免费畅玩入口_qq游戏电脑版快速启动
NVIDIA股价11月重挫12%:下月有望好转 但难回5万亿美元巅峰
Mudbox图层蒙版怎么用_Mudbox图层蒙版数字雕刻应用技巧
Win11蓝牙耳机断连怎么解决 Win11蓝牙设置重新配对与驱动更新【技巧】
HTML5原生日期选择器与jQuery UI:实现日期选择器的联动与程序化控制


2025-12-13
浏览次数:次
返回列表
)
->where('id', 1)
->update([
'preferences' => DB::raw("JSON_SET(preferences, '$.theme', 'light')")
]);
// 或用模型:$user->update(['preferences' => DB::raw("JSON_SET(...)")]);