MyBatis报错及解决方法 | BindingException: Type interface XXX is not known to the MapperRegistry.

本专栏主要是记录学习完JavaSE后学习JavaWeb部分的一些知识点总结以及遇到的一些问题等,如果刚开始学习Java的小伙伴可以点击下方连接查看专栏
本专栏地址:🔥JavaWeb
Java入门篇: 🔥Java基础学习篇
Java进阶学习篇(持续更新中):🔑Java进阶学习篇

在这里插入图片描述

一、报错场景

在使用MyBatis框架去查询数据库中的所有数据时,编写的测试类报错,无法查询到表内数据,并且数据库连接正常,之前的一个案例是可以成功查询的,但是自己新做的案例无法查询

二、报错信息

org.apache.ibatis.binding.BindingException: Type interface com.itheima.mapper.BrandMapper is not known to the MapperRegistry.
at org.apache.ibatis.binding.MapperRegistry.getMapper(MapperRegistry.java:47)
at org.apache.ibatis.session.Configuration.getMapper(Configuration.java:779)
at org.apache.ibatis.session.defaults.DefaultSqlSession.getMapper(DefaultSqlSession.java:291)
at com.itheima.test.MyBatisTest1.SelectAll(MyBatisTest1.java:29)

三、报错原因

没有获取BrandrMapper这个接口,但是在测试类中没有红色的报错,说明问题不是出在test类中,而是出在mapper文件或者配置文件中
在这里插入图片描述

BrandMapper.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">


<mapper namespace="com.itheima.mapper.BrandMapper">


    <select id="selectAll" resultType="Brand">
        SELECT  * FROM tb_brand;
    </select>
</mapper>

这里没有问题,那么就是配置文件mybatis-config.xml文件有问题

mybatis-config.xml文件

	
	···
	
	<environment id="test">
        <transactionManager type="JDBC"/>
        <dataSource type="POOLED">
            <!--数据库连接信息-->
            <property name="driver" value="com.mysql.jdbc.Driver"/>
            <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false"/>
            <property name="username" value="root"/>
            <property name="password" value="123456"/>
        </dataSource>
    </environment>

	···

<mappers>
    <!--SQL映射文件-->
    <mapper resource="com\itheima\mapper\UserMapper.xml"/>
</mappers>

test环境也已经配置好,数据库信息也完全正确,问题还是出在映射文件中:这里映射文件还是com\itheima\mapper\UserMapper.xml文件,但是我们需要的是BrandMapper文件,并且随着不断学习,Mapper文件会越来越多,因此在这里要改写一下这给语句

四、解决方法

我们把Mapper文件都写在同一个包下,所以这里映射文件只需要写包路径即可,这样就会自动检索mapper包下符合的SQL映射文件,修改完以后再运行一次就可以成功查询,也可以成功执行SQL语句

<mappers>
    <!--SQL映射文件-->
    <package name="com.itheima.mapper"/>
</mappers>

在这里插入图片描述

  • 13
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
回答: 这个问题是由于核心配置文件中加载映射文件的包名写错导致的。具体来说,错误的包名是"com_atguigu.mybatis.mapper.UserMapper",而正确的包名应该是"com.atguigu.mybatis.mapper.UserMapper"。这个错误会导致MyBatis无法识别到UserMapper接口。解决这个问题的方法是将包名修改为正确的形式,即将"com_atguigu.mybatis.mapper"改为"com.atguigu.mybatis.mapper"。这样就能够正确加载映射文件并解决该异常。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [解决 - org.apache.ibatis.binding.BindingException: Type interface com.itheima.mapper.UserMapper...](https://blog.csdn.net/weixin_51730356/article/details/129260822)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [解决org.apache.ibatis.binding.BindingException: Type interface is not known to the MapperRegistry.](https://blog.csdn.net/WHT869706733/article/details/123271534)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [org.apache.ibatis.binding.BindingException: Type interface xxx.Mapper is not known to the MapperRegi](https://blog.csdn.net/RadNICkMan/article/details/125381881)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Alita11101_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值