Mybatis遇到的坑

Posted 我的博客

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis遇到的坑相关的知识,希望对你有一定的参考价值。

最近再用mybatis搭建 ssm框架的时候,老是抱一个错误

Error creating document instance.  Cause: org.xml.sax.SAXParseException; lineNumber: 27; columnNumber: 17; 元素类型为 "configuration" 的内容必须匹配 "(properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,objectWrapperFactory?,plugins?,environments?,databaseIdProvider?,mappers?)"。
仔细看了一下自己的配置文件,发现并单词没有拼错啊,后来仔细看了一下说明文档,原来mybatis的配置是有顺序说明的 ,坑啊
MyBatis配置文件中大标签configuration下子标签包括:
configuration
|--- properties
|--- settings
|--- typeAliases
|--- typeHandlers
|--- objectFactory
|--- plugins
|--- environments
|--- |--- environment
|--- |--- |--- transactionManager
|--- |--- |__ dataSource
|__ mappers
另外还遇到一个错误,一并记录下来:
mybatis异常:Could not find result map java.util.Map 问题分析及解决
 
错误写法
  <select id="queryXXXCount" resultMap="java.util.Map" >
正确写法:
  <select id="queryXXXCount" resultType="java.util.Map">
  注解:
MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,resultType是直接表示返回类型的,而resultMap则是对外部ResultMap的引用,但是resultType跟resultMap不能同时存在。
在MyBatis进行查询映射时,其实查询出来的每一个属性都是放在一个对应的Map里面的,其中键是属性名,值则是其对应的值。
①当提供的返回类型属性是resultType时,MyBatis会将Map里面的键值对取出赋给resultType所指定的对象对应的属性。所以其实MyBatis的每一个查询映射的返回类型都是ResultMap,只是当提供的返回类型属性是resultType的时候,MyBatis对自动的给把对应的值赋给resultType所指定对象的属性。
②当提供的返回类型是resultMap时,因为Map不能很好表示领域模型,就需要自己再进一步的把它转化为对应的对象,这常常在复杂查询中很有作用。

以上是关于Mybatis遇到的坑的主要内容,如果未能解决你的问题,请参考以下文章

spring整合mybatis遇到的坑

Mybatis中Mapper.xml 文件使用注释遇到的坑

Mybatis中Mapper.xml 文件使用注释遇到的坑

记一次若依微服务版mybatis升级mybatis-plus之后遇到的坑

JAVA MyBatis 逆向工程 遇到的坑

Mybatis与SQL Server类型转换遇到的坑