有些时候,部分字段需要存储json数据
。
按照以往的操作,在create
的时候,先手动对特定的字段进行json_encode
,然后再create
;
而update
的时候,先手动json_decode
,修改完毕后再json_encode
,然后再update
;
想想都觉得麻烦,虽然可以使用laravel模型事件
,在对应的creating
或updating
的事件中去处理,但这也太大材小用了。
实际上模型中有casts
属性可以帮我们完成这个功能。
从 IlluminateDatabaseEloquentModel
找到 IlluminateDatabaseEloquentConcernsHasAttributes
,会发现有很多属性可供配置,
例如设置表名table
,是否维护时间戳timestamps
,可被批量赋值的属性fillable
,主键字段名(默认id
)primaryKey
,主键字段类型(默认int
)keyType
,主键是否自增(默认是)incrementing
,等等,这里主要说的是属性转换casts
,在模型中设置一下即可:
PHP
代码语言:javascript复制/**
* 类型转换
* @var string[]
*/protected $casts = [
'recharge => 'array',];
设置过后,从前端拿到的或者处理出来的字段array
数据,就不需要手动去json_encode
,update
时候也不要管,会自动帮我们转为json数据
进行存储。
但是需要注意的是,在create
的时候会进行属性转换处理,但是在更新的时候,如果是直接使用update
进行更新,则不会进行属性转换处理。
可参考:laravel模型事件-update触发updating和updated的问题
先使用first
或者find
获取模型后再操作即可,当然,updateOrCreate
也可以。。
收藏 | 0点赞 | 0打赏