Gon*_*alo 3 java spring-mybatis
我正在尝试调用休息应用程序,但出现 500 错误。问题可能出在 MyBatis 调用上,但仍然无法解决。
这就是我称之为 MyBatis 执行的地方
@Override
public List<IdentitatBDTO> searchIdentitatsRepresentantsByRelacioIdentitatRepresentat(final String representatIdentificador, final Date dateFi) {
List<Identitat> identitats = myBatisTemplate.execute(RelacioDao.class, new MyBatisDaoCallback<List<Identitat>>() {
@Override
public List<Identitat> execute(MyBatisDao dao) {
return ((RelacioDao) dao).searchIdentitatsRepresentantsByRelacioIdentitatRepresentat(representatIdentificador, dateFi);
}
});
Run Code Online (Sandbox Code Playgroud)
我得到的错误是
{
"errorUrl":
"http://localhost:8080/idjrepresentaciorest/rest/representacio/representants/12340002L",
"errorMessage": "\r\n### Error querying database. Cause: org.apache.ibatis.binding.BindingException: Parameter 'representatIdentificador' not found. Available parameters are [1, 0, param1, param2]\r\n### Cause: org.apache.ibatis.binding.BindingException: Parameter 'representatIdentificador' not found. Available parameters are [1, 0, param1, param2]",
"errorStackTrace": "org.apache.ibatis.exceptions.PersistenceException: \r\n### Error querying database. Cause: org.apache.ibatis.binding.BindingException: Parameter 'representatIdentificador' not found. Available parameters are [1, 0, param1, param2]\r\n### Cause: org.apache.ibatis.binding.BindingException: Parameter 'representatIdentificador' not found. Available parameters are [1, 0, param1, param2]\r\n\tat org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30)\r\n\tat org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:150)\r\n\tat org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:141)\r\n\tat org.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:137)\r\n\tat org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:75)\r\n\tat org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)\r\n\tat com.sun.proxy.$Proxy85.searchIdentitatsRepresentantsByRelacioIdentitatRepresentat(Unknown Source)\r\n\tat es.bcn.idj.representaciorest.business.impl.RelacioServiceImpl$1.execute(RelacioServiceImpl.java:61)\r\n\tat es.bcn.idj.representaciorest.business.impl.RelacioServiceImpl$1.execute(RelacioServiceImpl.java:1)\r\n\tat net.opentrends.openframe.services.persistence.mybatis.template.impl.MyBatisTemplateImpl.execute(MyBatisTemplateImpl.java:64)\r\n\tat
Run Code Online (Sandbox Code Playgroud)
但是我调试了一下,发现问题所在的变量被正确填充了,那么为什么MyBatis 没有创建这个变量呢?
小智 7
@Param注解有两种,一种属于spring,一种属于mybatis。它们的用法不同。
User getUserById(@Param("id") Integer id);
<select id="getUserById" resultMap="userMap">
select name,age
from user
where id=#{0, jdbcType=INTEGER}
<select/>
Run Code Online (Sandbox Code Playgroud)
它基于参数的顺序,从 0 开始。User getUserById(@Param("id") Integer id);
<select id="getUserById" resultMap="userMap">
select name,age
from user
where id=#{id, jdbcType=INTEGER}
<select/>
Run Code Online (Sandbox Code Playgroud)
基于参数名称。因此,请检查您在 mapper.java 中引入的注释是否与 mapper.xml 中的用法一致。
| 归档时间: |
|
| 查看次数: |
10912 次 |
| 最近记录: |