问题是:我打一个比方:
protected $serializeField = array( 'info' => array('id1', 'status1', 'content1','id2', 'status2', 'content2,'id3', 'status3', 'content3'));,当你第一次插入的时候,插入可以使用$data数组然后add($data)的形式,也可以使用数据对象的形式,比方$data = array('id1'=>100, 'status1'=>1, 'content1'=>'很好的方案');使用$id = D('模型')->add($data);这样的话$data 就自动储存到数据库的info字段中去了!然而,当你更新的时候,比方$data = array('id2'=>10110, 'status2'=>1, 'content2'=>'搜噶');采用 D('模型')->where()->add($data);问题来了,你会发现关于1的所有数据都丢失了,id1,content1,status1都没了,只剩下关于2的数据了,这不是我想要的!我想要的效果是增加的东西要追加在这个字段的后面,我 的解决方法是:就是你在更新之前先取出之前的序列化的数组,我称之为$before,跟你要插入的$data 做一个$new = array_merge($before,$data),$before一定要放在前面,为什么自己想去!然后add($new);如果你用的数据对象的形式add,那还是要注意顺序,先把原先的搞到数据对象里面去,然后再把新的搞到数据对象中,以防止有重复的字段!我觉得这种方案就很完美的解决了高级模型更新数据的时候丢失数据的问题!好了,我的方案可能也不是太好,目前就只能这么解决,如果有问题或者你有更好的解决拌饭,请在下面留言或者加我Q13108302一起交流!
最佳答案