mybatis学习笔记--常见的错误
原文来自:《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配置文件
plain copy
- <mappers>
- <mapper resource="esd/db/mapper/ResumeMapper.xml" />
- </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重复了,就会报这个错.
- <!-- 按code码得到一个对象-->
- <select id="getByCode" resultType="Geography"
- parameterType="java.lang.String">
- select * from Geography where code = ${code}
- </select>
- <!-- 按地名getByName得到一个对象-->
- <select id="getByCode" resultType="Geography"
- parameterType="java.lang.String">
- select * from Geography where fullName = ${fullName}
- </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'
- <!-- 这个属性是多余的,在对应的bean类中没有对应的字段,删除后OK -->
- <if test="education != null and education != ''">
- education = #{education},
- </if>
在mapper配置文件中删除多配置的属性/或则在自己的bean类中补全该字段
4.<if>标签中不支持 && 符号
错误:
The entity name must immediately follow the '&' in the entity reference
解析不了 && 是什么东东
- <update id="update" parameterType="Geography">
- update Geography
- <trim prefix="set" suffixOverrides=",">
- <if test="code != null && code !=''">
- code=#{code},
- </if>
- <if test="name != null && name != ''">
- name=#{name},
- </if>
- </trim>
- where id= #{id}
- </update>
解决方法:使用正确的语法咯,别用&&,用and
- <!-- update -->
- <update id="update" parameterType="Geography">
- update Geography
- <trim prefix="set" suffixOverrides=",">
- <if test="code != null and code !=''">
- code=#{code},
- </if>
- <if test="name != null and name != ''">
- name=#{name},
- </if>
- </trim>
- where id= #{id}
- </update>
5.返回结果类型写错
由于我的项目配置原因, debug 输出信息中没有报错, 但是项目就是启动不起来, 所以没能截到错误信息提示, 以后遇到会补上
具体说就是: 如果自定义了返回的结果集, 返回的类型一定要是resultMap类型,(下面是错误示例) 如下
- <!-- 查询Area 地名 -->
- <resultMap id="ResultArea" type="Area">
- <id column="a_code" property="code" />
- <result column="a_name" property="name" />
- <result column="a_pyName" property="pyName" />
- <result column="a_abbr" property="abbr" />
- <result column="a_mark" property="mark" />
- </resultMap>
- <!-- 查询Parameter 地名 -->
- <resultMap id="ResultParameter" type="Parameter">
- <id column="p_id" property="id" />
- <result column="p_name" property="name" />
- <result column="p_value" property="value" />
- <result column="p_type" property="type" />
- <result column="p_mark" property="mark" />
- <association property="area" javaType="Parameter" resultMap="ResultArea" />
- </resultMap>
- <!-- get by id -->
- <select id="getById" resultType="ResultParameter" parameterType="int">
- 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,
- 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
- from parameter as p, area as a
- where p.acode = a.code and id = #{id}
- </select>
如上例中, 我定义了'ResultParameter'的结果集, 那么下面表连接查询的时候,如果返回的是表连接查询结果, 那么一定要使用 resultMap="ResultParameter", 否则万一提示信息中没有显示出来, 要费些时间才能找出来.
6. 标签顺序写错
错误:
The content of element type "resultMap" must match "(constructor?,id*,result*,association*,collection*,discriminator?)".
下午的时候无意中遇到这个错误, 下面是错误代码:
- <resultMap id="ResultMenu" type="com.esd.hesf.model.Menu">
- <id column="id" property="id" jdbcType="CHAR" />
- <result column="text" property="text" jdbcType="VARCHAR" />
- <result column="iconcls" property="iconcls" jdbcType="VARCHAR" />
- <association property="permissionType" javaType="com.esd.hesf.model.PermissionType" resultMap="ResultPermissionType"/>
- <result column="update_time" property="updateTime" jdbcType="TIMESTAMP" />
- </resultMap>
- <resultMap id="ResultMenu" type="com.esd.hesf.model.Menu">
- <id column="id" property="id" jdbcType="CHAR" />
- <result column="text" property="text" jdbcType="VARCHAR" />
- <result column="iconcls" property="iconcls" jdbcType="VARCHAR" />
- <result column="update_time" property="updateTime" jdbcType="TIMESTAMP" />
- <association property="permissionType" javaType="com.esd.hesf.model.PermissionType" resultMap="ResultPermissionType"/>
- </resultMap>
7.多写了if判断
错误:
org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'year' in 'class java.lang.String'
下面是代码:
dao层方法
- /**
- * 查询审核报表情况--按公司类型查
- * @return
- */
- List<ReportViewModel> retrieveReportByCompanyType(String year);
- <!-- retrieve report statistics by company type -->
- <select id="retrieveReportByCompanyType" parameterType="java.lang.String" resultMap="ReportViewModel">
- select
- <include refid="report_column_list"/>
- from audit_company_view
- <where>
- <if test="year != null and year != ''">
- au_year = #{year,jdbcType=CHAR}
- </if>
- </where>
- group by t_id
- </select>
- <if test="year != null and year != ''">
- <!-- retrieve report statistics by company type -->
- <select id="retrieveReportByCompanyType" parameterType="java.lang.String" resultMap="ReportViewModel">
- select
- <include refid="report_column_list"/>
- from audit_company_view
- <where>
- au_year = #{year,jdbcType=CHAR}
- </where>
- group by t_id
- </select>
那问题出来了, 我怎么判断传进来的单个字符串是否为空值呢? 这是否是mybatis的一个小bug呢? 答案尚在查找中, 有了会第一时间贴上来的.
mybatis学习笔记--常见的错误的更多相关文章
- Mybatis学习笔记(二) 之实现数据库的增删改查
开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包.这些软件工具均可以到各自的官方网站上下载 ...
- MyBatis:学习笔记(1)——基础知识
MyBatis:学习笔记(1)--基础知识 引入MyBatis JDBC编程的问题及解决设想 ☐ 数据库连接使用时创建,不使用时就释放,频繁开启和关闭,造成数据库资源浪费,影响数据库性能. ☐ 使用数 ...
- mybatis学习笔记(五) -- maven+spring+mybatis从零开始搭建整合详细过程(附demo和搭建过程遇到的问题解决方法)
文章介绍结构一览 一.使用maven创建web项目 1.新建maven项目 2.修改jre版本 3.修改Project Facts,生成WebContent文件夾 4.将WebContent下的两个文 ...
- mybatis学习笔记(五):mybatis 逆向工程
mybatis学习笔记(五):mybatis 逆向工程 在日常开发中,如果数据库中存在多张表,自己手动创建 多个pojo 类和编写 SQL 语法配置文件,未免太过繁琐,mybatis 也提供了一键式生 ...
- mybatis 学习笔记(二):mybatis SQL注入问题
mybatis 学习笔记(二):mybatis SQL注入问题 SQL 注入攻击 首先了解下概念,什么叫SQL 注入: SQL注入攻击,简称SQL攻击或注入攻击,是发生于应用程序之数据库层的安全漏洞. ...
- 【MyBatis学习笔记】
[MyBatis学习笔记]系列之预备篇一:ant的下载与安装 [MyBatis学习笔记]系列之预备篇二:ant入门示例 [MyBatis学习笔记]系列之一:MyBatis入门示例 [MyBatis学习 ...
- MyBatis:学习笔记(3)——关联查询
MyBatis:学习笔记(3)--关联查询 关联查询 理解联结 SQL最强大的功能之一在于我们可以在数据查询的执行中可以使用联结,来将多个表中的数据作为整体进行筛选. 模拟一个简单的在线商品购物系统, ...
- mybatis学习笔记(四)-- 为实体类定义别名两种方法(基于xml映射)
下面示例在mybatis学习笔记(二)-- 使用mybatisUtil工具类体验基于xml和注解实现 Demo的基础上进行优化 以新增一个用户为例子,原UserMapper.xml配置如下: < ...
- mybatis学习笔记(二)-- 使用mybatisUtil工具类体验基于xml和注解实现
项目结构 基础入门可参考:mybatis学习笔记(一)-- 简单入门(附测试Demo详细过程) 开始体验 1.新建项目,新建类MybatisUtil.java,路径:src/util/Mybatis ...
随机推荐
- linux driver ------ platform模型,通过杂项设备(主设备号是10)注册设备节点
注册完设备和驱动之后,就需要注册设备节点 Linux杂项设备出现的意义在于:有很多简单的外围字符设备,它们功能相对简单,一个设备占用一个主设备号对于内核资源来说太浪费.所以对于这些简单的字符设备它们共 ...
- linux反向删除文件
Linux反选删除文件 最简单的方法是 # shopt -s extglob (打开extglob模式) # rm -fr !(file1) 如果是多个要排除的,可以这样: # rm -r ...
- python os模块 常用命令
python编程时,经常和文件.目录打交道,这是就离不了os模块.os模块包含普遍的操作系统功能,与具体的平台无关.以下列举常用的命令 1. os.name()——判断现在正在实用的平台,Window ...
- Nvivo
sklearn实战-乳腺癌细胞数据挖掘(博客主亲自录制视频教程) https://study.163.com/course/introduction.htm?courseId=1005269003&a ...
- 20190312 Windows安装Kafka
1. 下载 使用版本2.1.1 官网下载地址 2. 安装 2.1. 前提 已安装ZooKeeper,可参考 20190311 Windows安装ZooKeeper 进行安装ZooKeeper 2.2. ...
- Oracle导出数据中的prompt,set feedback 等是什么意思
prompt 显示后面的提示,相当于一般的操作系统命令echo,输出后面的信息Importing table t_testset feedback off 1.set feedback 有三种方式: ...
- thread join和detach的区别
线程状态: 在一个线程的生存期内,可以在多种状态之间转换,不同的操作系统可以实现不同的线程模型,定义许多不同的线程状态,每个状态还可以包含多个子状态,但大体来说,如下几种状态是通用的: 1)就绪:参与 ...
- Hive记录-配置远程连接(JAVA/beeline)
1.修改配置hive-site.xml hadoop core-site.xml限制---参考Hive记录-部署Hive环境 2.启动hadoop #sh /usr/app/hadoop/sbi ...
- 原生js的ajax请求
传统方法的缺点: 传统的web交互是用户触发一个http请求服务器,然后服务器收到之后,在做出响应到用户,并且返回一个新的页面,,每当服务器处理客户端提交的请求时,客户都只能空闲等待,并且哪怕只是一次 ...
- VMware虚拟机Mac OS X无法调整扩展硬盘大小的解决方案(转)
使用VMware虚拟机搭建的MacOSX,在10.10以上可能会出现无法扩充磁盘大小的问题. 因为很多朋友在初次安装MacOSX的时候都默认选择40G的磁盘大小,结果用了没两天之后就发现磁盘不够用了. ...