报错:SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry 'admin'

2021-12-08 15:23:20 浏览数 (1)

在提交注册信息的时候报错:SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry 'admin' for key 'username'

原因:主键冲突 违反完整性约束 字段唯一索引

从上图可以看出,用户名和邮箱必须唯一,如果填入重复的用户名或者邮箱就会出错

解决方法:在控制器里面进行判断

代码语言:javascript复制
data=input(′post.′);data = input('post.'); data=input(′post.′);uniquename = model('User')->get(['username'=>data['username']]);  if(sizeof(uniquename)){
 this->error('该用户名已经注册,请重新填写~~~');  } uniqueemail = model('User')->get(['email'=>data['email']]);  if(sizeof(uniqueemail)){
 $this->error('该邮箱已经注册,请重新填写~~~');
 }

添加上面代码之后,如果填写了重复的用户名或者密码就会给用户相关提示~~~

对了,上面的代码是在TP5上写的。

0 人点赞