![图片上传中...]
public function addUserBasicData($username,$password,$user_type,$email,$phone,$onlyuid = '598E0CD9'){
if (empty($username)) {
$username = "用户".mt_rand();
}
$data['username'] = $username;
$data['onlyuid'] = $onlyuid;
$data['password'] = $password;
$data['user_type'] = $user_type;
$data['email'] = $email;
$data['phone'] = $phone;
$data['regdate'] = NOW_TIME;
$rules = array(
array('onlyuid','','身份重复',0,'unique',1),
array('phone','require','手机号码非法','/^(13|14|15|16|17|18)\d{9}$$/'),
array('phone','','您输入手机号码已经被注册!',0,'unique',1),
array('email','','您输入电子邮箱已经被注册!',0,'unique',1),
array('password','require','您尚未填写密码!'),
array('user_type','require','您尚未选择用户类型!'),
array('repassword','password','确认密码不正确',0,'confirm'),
array('password','checkPwd','密码格式不正确',0,'function'),
);
if (!$this->table('yy_common_member')->validate($rules)->create()){
$return_value["status"] = "failed";
$return_value["status_code"] = 40000;
$return_value["status_message"] = $this->getError();;
$return_value["data"]= "";
return $return_value;
}else{
$uid = $this->table('yy_common_member')->add($data);
$data2['uid'] = $uid;
$return_value["status"] = "success";
$return_value["status_code"] = 20105;
$return_value["status_message"] = "";
$return_value["data"]= $this->table('yy_common_member_profile')->add($data2);
return $return_value;
}
}
以上是代码片段
分别设置了
array('onlyuid','','身份重复',0,'unique',1), 和 array('phone','','您输入手机号码已经被注册!',0,'unique',1),
的验证规则。
但前者不生效,后者可以使用
报错
正常
这明显是sql语句报错,跟验证没关系,插入的onlyuid重复了
你数据库中onlyuid字段的数据类型是什么?
大家说的没错:原因在数据库那里,你试图插入重复的onlyuid,而这个字段显然被设定为唯一的。
检查一下吧,如果这个字段字面意义不是很强,建议用自增形式,每次插入数据时不要直接跳过这个字段,让他自己增加。
还有一种可能,这个字段要插入的值已经超过它允许的最大值了。