thinkphp 3.2.2 bug

浏览:938 发布日期:2014/10/17 分类:求助交流 关键字: bug bug提交
thinkphp 3.2.2 使用模型创建数据对象create()方法后使用field()方法过虑更新字段失效,代码如下:
$validate=array(
array('name','','用户名已存在',0,'unique',1),
array('email','','登陆邮箱已存在',0,'unique',1)
);
$data=$this->model->validate($validate)->create();
if(!$data){
$this->error($this->model->getError());
}else{
$op=$data['id'] ? '编辑' : '添加';
$field='';
if($data['password']){//添加 编辑 管理员,设置了密码
$data['password']=md5($data['password']);
$field='name,email,password,status';
p($field,1);
}elseif($data['id']&&!$data['password']){//编辑管理员,未设置新密码
$field='name,status';
p($field,1);//流程走的这一句,输出了name,status
}
$result=$data['id'] ? $this->model->field($field)->save($data) : $this->model->field($field)->add();
我指定只更新name,status两个字段,但是实际上更新了数据对象中的所有字段name,email,password,status
实际执行的sql语句:
UPDATE `think_user` SET `name`='用户管理员',`email`='user@user.com',`password`='',`status`='1' WHERE `id` = '3'
应该是bug
最佳答案
评论( 相关
后面还有条评论,点击查看>>