原文来自:《mybatis学习笔记--常见的错误


昨天刚学了下mybatis,用的是3.2.2的版本,在使用过程中遇到了些小问题,现总结如下,会不断更新.

1.没有在configuration.xml配置对应的sql配置文件

错误:

Error updating database. Cause: java.lang.IllegalArgumentException:
Mapped Statements collection does not contain value for ***Mapper.*** Cause:
java.lang.IllegalArgumentException: Mapped Statements collection does not
contain value for ***Mapper.***
解决方法:

在configuration.xml配置文件中引用对应的sql配置文件

[html] view
plain
 copy

  1. <mappers>
  2. <mapper resource="esd/db/mapper/ResumeMapper.xml" />
  3. </mappers>

2.同一sql配置文件中id重复

错误:

Cause: org.apache.ibatis.builder.BuilderException: Error parsing SQL Mapper Configuration. Cause: java.lang.RuntimeException: Error parsing Mapper XML. Cause: java.lang.IllegalArgumentException: Mapped Statements collection already contains value for GeographyMapper.getByCode
两个sql语句的id重复了,就会报这个错.
[html] view plain copy
  1. <!-- 按code码得到一个对象-->
  2. <select id="getByCode" resultType="Geography"
  3. parameterType="java.lang.String">
  4. select * from Geography where code = ${code}
  5. </select>
  6. <!-- 按地名getByName得到一个对象-->
  7. <select id="getByCode" resultType="Geography"
  8. parameterType="java.lang.String">
  9. select * from Geography where fullName = ${fullName}
  10. </select>
解决方法:

修改其中的一个id就ok了.
3.mapper配置文件中为bean类配置的属性没有在对应的bean类中找到对应的字段

错误:

Error updating database.  Cause: org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'education' in 'class esd.bean.Personal'
Cause: org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'education' in 'class esd.bean.Personal'

[html] view plain copy
  1. <!-- 这个属性是多余的,在对应的bean类中没有对应的字段,删除后OK -->
  2. <if test="education != null and education != ''">
  3. education = #{education},
  4. </if>
解决方法:

在mapper配置文件中删除多配置的属性/或则在自己的bean类中补全该字段

4.<if>标签中不支持 && 符号

错误:

The entity name must immediately follow the '&' in the entity reference

解析不了 && 是什么东东

[html] view plain copy
  1. <update id="update" parameterType="Geography">
  2. update Geography
  3. <trim prefix="set" suffixOverrides=",">
  4. <if test="code != null && code !=''">
  5. code=#{code},
  6. </if>
  7. <if test="name != null && name != ''">
  8. name=#{name},
  9. </if>
  10. </trim>
  11. where id= #{id}
  12. </update>

解决方法:使用正确的语法咯,别用&&,用and

[html] view plain copy
  1. <!-- update -->
  2. <update id="update" parameterType="Geography">
  3. update Geography
  4. <trim prefix="set" suffixOverrides=",">
  5. <if test="code != null and code !=''">
  6. code=#{code},
  7. </if>
  8. <if test="name != null and name != ''">
  9. name=#{name},
  10. </if>
  11. </trim>
  12. where id= #{id}
  13. </update>

5.返回结果类型写错

由于我的项目配置原因, debug 输出信息中没有报错, 但是项目就是启动不起来, 所以没能截到错误信息提示, 以后遇到会补上

具体说就是: 如果自定义了返回的结果集, 返回的类型一定要是resultMap类型,(下面是错误示例) 如下

[html] view plain copy
  1. <!-- 查询Area 地名 -->
  2. <resultMap id="ResultArea" type="Area">
  3. <id column="a_code" property="code" />
  4. <result column="a_name" property="name" />
  5. <result column="a_pyName" property="pyName" />
  6. <result column="a_abbr" property="abbr" />
  7. <result column="a_mark" property="mark" />
  8. </resultMap>
  9. <!-- 查询Parameter 地名 -->
  10. <resultMap id="ResultParameter" type="Parameter">
  11. <id column="p_id" property="id" />
  12. <result column="p_name" property="name" />
  13. <result column="p_value" property="value" />
  14. <result column="p_type" property="type" />
  15. <result column="p_mark" property="mark" />
  16. <association property="area" javaType="Parameter" resultMap="ResultArea" />
  17. </resultMap>
  18. <!-- get by id -->
  19. <select id="getById" resultType="ResultParameter" parameterType="int">
  20. select p.id as p_id, p.name as p_name, p.value as p_value, p.type as p_type, p.mark as p_mark,
  21. a.code as a_code, a.name as a_name, a.pyname as a_pyName, a.abbr as a_abbr, a.mark as a_mark
  22. from parameter as p, area as a
  23. where p.acode = a.code and id = #{id}
  24. </select>
常用在表连接查询中.

如上例中, 我定义了'ResultParameter'的结果集,  那么下面表连接查询的时候,如果返回的是表连接查询结果, 那么一定要使用 resultMap="ResultParameter", 否则万一提示信息中没有显示出来, 要费些时间才能找出来.

6. 标签顺序写错

错误:

The content of element type "resultMap" must match "(constructor?,id*,result*,association*,collection*,discriminator?)".

下午的时候无意中遇到这个错误, 下面是错误代码:

[html] view plain copy
  1. <resultMap id="ResultMenu" type="com.esd.hesf.model.Menu">
  2. <id column="id" property="id" jdbcType="CHAR" />
  3. <result column="text" property="text" jdbcType="VARCHAR" />
  4. <result column="iconcls" property="iconcls" jdbcType="VARCHAR" />
  5. <association property="permissionType" javaType="com.esd.hesf.model.PermissionType" resultMap="ResultPermissionType"/>
  6. <result column="update_time" property="updateTime" jdbcType="TIMESTAMP" />
  7. </resultMap>
在<resultMap 处画红线,   原因是: 里面的<association />标签, 一定要放在这组标签最下面.  如下:
[html] view plain copy
  1. <resultMap id="ResultMenu" type="com.esd.hesf.model.Menu">
  2. <id column="id" property="id" jdbcType="CHAR" />
  3. <result column="text" property="text" jdbcType="VARCHAR" />
  4. <result column="iconcls" property="iconcls" jdbcType="VARCHAR" />
  5. <result column="update_time" property="updateTime" jdbcType="TIMESTAMP" />
  6. <association property="permissionType" javaType="com.esd.hesf.model.PermissionType" resultMap="ResultPermissionType"/>
  7. </resultMap>

7.多写了if判断

错误:

org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'year' in 'class java.lang.String'

下面是代码:

dao层方法

[java] view plain copy
  1. /**
  2. * 查询审核报表情况--按公司类型查
  3. * @return
  4. */
  5. List<ReportViewModel> retrieveReportByCompanyType(String year);
mapper配置文件
[html] view plain copy
  1. <!-- retrieve report statistics by company type -->
  2. <select id="retrieveReportByCompanyType" parameterType="java.lang.String" resultMap="ReportViewModel">
  3. select
  4. <include refid="report_column_list"/>
  5. from audit_company_view
  6. <where>
  7. <if test="year != null and year != ''">
  8. au_year = #{year,jdbcType=CHAR}
  9. </if>
  10. </where>
  11. group by t_id
  12. </select>
一般这个错是指参数parameterType类型的字段 没有get, set方法, 我只是传个String类型的参数, so 刚遇到这个问题的时候, 有点摸不着头脑, 怎么会报这个错呢? 原来问题出现在配置文件中:
[html] view plain copy
  1. <if test="year != null and year != ''">
mybatis自动将if判断中的字段默认为传进来的parameterType类型的字段了... so....只要将这个if判断去掉即可.
[html] view plain copy
  1. <!-- retrieve report statistics by company type -->
  2. <select id="retrieveReportByCompanyType" parameterType="java.lang.String" resultMap="ReportViewModel">
  3. select
  4. <include refid="report_column_list"/>
  5. from audit_company_view
  6. <where>
  7. au_year = #{year,jdbcType=CHAR}
  8. </where>
  9. group by t_id
  10. </select>

那问题出来了, 我怎么判断传进来的单个字符串是否为空值呢? 这是否是mybatis的一个小bug呢?  答案尚在查找中, 有了会第一时间贴上来的.

mybatis学习笔记--常见的错误的更多相关文章

  1. Mybatis学习笔记(二) 之实现数据库的增删改查

    开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包.这些软件工具均可以到各自的官方网站上下载 ...

  2. MyBatis:学习笔记(1)——基础知识

    MyBatis:学习笔记(1)--基础知识 引入MyBatis JDBC编程的问题及解决设想 ☐ 数据库连接使用时创建,不使用时就释放,频繁开启和关闭,造成数据库资源浪费,影响数据库性能. ☐ 使用数 ...

  3. mybatis学习笔记(五) -- maven+spring+mybatis从零开始搭建整合详细过程(附demo和搭建过程遇到的问题解决方法)

    文章介绍结构一览 一.使用maven创建web项目 1.新建maven项目 2.修改jre版本 3.修改Project Facts,生成WebContent文件夾 4.将WebContent下的两个文 ...

  4. mybatis学习笔记(五):mybatis 逆向工程

    mybatis学习笔记(五):mybatis 逆向工程 在日常开发中,如果数据库中存在多张表,自己手动创建 多个pojo 类和编写 SQL 语法配置文件,未免太过繁琐,mybatis 也提供了一键式生 ...

  5. mybatis 学习笔记(二):mybatis SQL注入问题

    mybatis 学习笔记(二):mybatis SQL注入问题 SQL 注入攻击 首先了解下概念,什么叫SQL 注入: SQL注入攻击,简称SQL攻击或注入攻击,是发生于应用程序之数据库层的安全漏洞. ...

  6. 【MyBatis学习笔记】

    [MyBatis学习笔记]系列之预备篇一:ant的下载与安装 [MyBatis学习笔记]系列之预备篇二:ant入门示例 [MyBatis学习笔记]系列之一:MyBatis入门示例 [MyBatis学习 ...

  7. MyBatis:学习笔记(3)——关联查询

    MyBatis:学习笔记(3)--关联查询 关联查询 理解联结 SQL最强大的功能之一在于我们可以在数据查询的执行中可以使用联结,来将多个表中的数据作为整体进行筛选. 模拟一个简单的在线商品购物系统, ...

  8. mybatis学习笔记(四)-- 为实体类定义别名两种方法(基于xml映射)

    下面示例在mybatis学习笔记(二)-- 使用mybatisUtil工具类体验基于xml和注解实现 Demo的基础上进行优化 以新增一个用户为例子,原UserMapper.xml配置如下: < ...

  9. mybatis学习笔记(二)-- 使用mybatisUtil工具类体验基于xml和注解实现

    项目结构  基础入门可参考:mybatis学习笔记(一)-- 简单入门(附测试Demo详细过程) 开始体验 1.新建项目,新建类MybatisUtil.java,路径:src/util/Mybatis ...

随机推荐

  1. malloc创建三维数组

    #include <stdio.h> #include <stdlib.h> #include <malloc.h> int main() { //f[0],f[] ...

  2. c#连接Redis Redis的安装与配置

    Redis是一个不错的缓存数据库,读取数据速度效率都很不错.今天大家共同研究下redis的用法.结合网上的资料和自己的摸索,先来看下安装与配置把. 咱们主要看在WINDOWS上怎样使用REDIS数据库 ...

  3. JS,JQ及时监听input值的变化,MUI的input搜索框里的清除按钮的点击监听事件

    JS: document.getElementById("input对象的ID").addEventListener('input',function(){ console.log ...

  4. UML类关系(依赖,关联,聚合,组合,泛化,实现)

    转自https://blog.csdn.net/k346k346/article/details/59582926   在学习面向对象设计时,类关系涉及依赖.关联.聚合.组合和泛化这五种关系,耦合度依 ...

  5. pandas使用

    一.pd.cut()与pd.qcut()的区别 假设有一组人员数据,而你希望将它们划分为不同的年龄组 ages = [18,20,22,25,27,21,23,37,31,61,45,32] bins ...

  6. saltstack安装与配置

    Saltstack是基于Python开发的一套C/S架构,具备Puppet.Ansible功能于一身的配置管理工具,功能十分强大,各模块融合度及复用性极高:使用号称世界上最快的消息队列ZeroMQ使得 ...

  7. python自动化运维之路~DAY4

    python自动化运维之路~DAY4   作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.模块导入方式详解. 关于Python有几种导入模块的方式,请参考我的另外一篇博客(第20 ...

  8. 读取Easy UI的DATa grid里面的所有数据

    目前我知道的有两种方法: 1.读取行数,循环读出 $("#btnEcxel").click(function () { var rows = $('#tbVehicleList') ...

  9. js格式化日期工具类

    就是一个工具类  开箱即用 传进一个指定的参数,格式化 //将时间戳格式化 function getMyDate(time){ if(typeof(time)=="undefined&quo ...

  10. canvas实现时钟

    最近在看新浪体育网球频道(http://sports.sina.com.cn/tennis/)的时候,看到了下面的劳力士广告的时钟是用canvas做的,于是也实现了一个简单的canvas时钟.直接上代 ...