配置MyBatis时报错信息的解决方案
程序员文章站
2022-04-10 09:36:53
...
在配置MyBatis时报错信息如下:
Invalid bound statement (not found): com.shizongger.chapter2.mapper.UserMapper.insertUser
简单的理解就是找不到正确的语句。一般是由于mapper.xml和mapper.java的文件不匹配造成的。引入映射器大致有四种方法:
1.用文件路径引入映射器
<mapper resource="com/shizongger/chapter2/mapper/RoleMapper.xml" /> <mapper resource="com/shizongger/chapter2/mapper/UserMapper.xml" />
2.用包名引入映射器
<package name="com.shizongger.chapter2.mapper" />
3.用类注册引入映射器
<mapper class="com.shizongger.chapter2.mapper.UserMapper" /> <mapper class="com.shizongger.chapter2.mapper.RoleMapper"/>
4.xxxMapper.xml引入映射器
<mapper url="file:/home/shizongger/workspace/Chapter3/src/com/shizongger/chapter2/mapper/RoleMapper.xml" /> <mapper url="file:/home/shizongger/workspace/Chapter3/src/com/shizongger/chapter2/mapper/UserMapper.xml"/>
这四种引入mapper的方式各有特点,我建议使用第一种或者第二种使用扫描的包的方式。但是在使用第二种的时候要注意:一定要把xxxMapper.java和xxxMapper.xml两者名字一模一样!
本次报错的原因是因为本人把UserMapper.xml错写成userMapper.xml,开头使用了小写,导致程序扫描包的时候扫描不到该mapper而出错。
我为什么会犯此错误?因为我在参考《深入浅出MyBatis技术原理与实践》(电子工业出版社-杨开振著)第3章57页的时候,作者给出了userMapper.xml的代码案例,并以小写作为userMapper.xml文件的开头。且在72页用到mapper.xml的地方,作者都有小写作为mapper.xml开头的习惯。本人误认为是MyBatis默认要求符合驼峰命名法且第一字母必须小写而导致的。
所以,在这里奉劝写技术书籍的作者不要浮躁,要对得起读者啊!
以上就是配置MyBatis时报错信息的解决方案的详细内容,更多请关注其它相关文章!
上一篇: html5 canvas (三)
推荐阅读
-
用户为scott时,用pl/sql登录oracle,报错问题的解决方案
-
连接MySQL报错误代码 ERROR 1045时的解决方案
-
ssm框架集成时,在spring配置文文件中集成mybatis时,在sqlSessionFactory中的属性configuration配置日志出错
-
Springboot2.X版本整合Mybatis时yml文件的配置问题
-
Python.Scrapy爬虫运行(scrapy.cfg和路径皆正确时)报错的解决方案
-
Java JDBC的 url 配置信息和Mybatis核心配置文件(MySQL 的配置信息)
-
Sublime Text4 配置 Python3 环境、代码提示、编译报错的解决方案
-
Mybatis Plus查询时sql字段名大小写报错的解决
-
Mybatis-Plus 全局配置无效的解决方案
-
rabbitmq配置类RabbitConfig中注入RabbitTemplate后在下面设置@BeanRabbitTemplate设置消息确认时springboot启动报错的问题