本专栏主要是记录学习完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>