>  기사  >  백엔드 개발  >  thinkphp3.2.3 表单验证 unique报错

thinkphp3.2.3 表单验证 unique报错

WBOY
WBOY원래의
2016-06-20 12:47:141197검색

protected $_validate = array(    // array(field,rule,message,condition,type,when,params)        // 1 用户不能为空,唯一,至少4个字符        array('username', '', '用户名已存在', 0, 'unique'),    );

在表单输入相同的名字 报SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '100' for key 'PRIMARY'
数据库相同的名字的位置,而不是输出错误信息。这是那里错了?


回复讨论(解决方案)

报错提示: Integrity constraint violation: 1062 Duplicate entry '100' for key 'PRIMARY'
该是整型的主键字段。而你给了字符串'100'。什么情况

主键id100那行的username是相同的输入
而且还有一个错误
所有错误消息都报非法数据对象!

请贴出控制器里处理表单的代码

是控制器里处理表单代码逻辑错了
        $user = new \Model\UserModel();
        
        if (!empty($_POST)) {
            $_POST['user_hobby'] = implode(',', $_POST['user_hobby']);
            
            // create方法收集表单信息并返回,同时触发表单自动验证
            $data = $user->create();    //  model设置$_validate // 如果设置了数据自动验证则进行数据验证
              if ($user->add($data)) {
                  echo '添加数据成功';
              } else {
                  dump($user->getError());
              }
        } else {
            $this->display();
        }
    }

改成
 if ($data) {
                  echo '添加数据成功';
              } else {
                  dump($user->getError());
                  return;
              }
              $user->add($data);
就好了,
不过为什么会这样

打印出$data看看,给出表结构。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.