用mybatis执行select方法报java.sql.SQLIntegrityConstraintViolationException: ORA-00001: 违反唯一约束条件 (HR.SYS_C004152)
异常信息如下:
### The error may exist in com/baizhi/dao/UserDao.java (best guess)
### The error may involve com.baizhi.dao.UserDao.selectUser-Inline
### The error occurred while setting parameters
### SQL: insert into t_buser values (se_buser.nextval,?,?)
### Cause: java.sql.SQLIntegrityConstraintViolationException: ORA-00001: 违反唯一约束条件 (HR.SYS_C004152)
at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:150)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:141)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:77)
at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:82)
at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:59)
at com.sun.proxy.$Proxy12.selectUser(Unknown Source)
at com.baizhi.service.impl.UserServiceImpl.login(UserServiceImpl.java:28)
at com.baizhi.action.userAction.login(userAction.java:42)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
原因是因为使用注解错误,错误代码如下:
@Insert("select * from t_buser where username=#{id}")
void insertUser(User u);
@Select("insert into t_buser values (se_buser.nextval,#{username},#{password})")
@ResultType(User.class)
User selectUser(String username);