SqlMapConfig.xml代码如下
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<!--mybatis的主配置文件-->
<configuration>
<!--配置环境-->
<environments default="mysql">
<!--配置mysql的环境-->
<environment id="mysql">
<!--配置事务的环境-->
<transactionManager type="JDBC"></transactionManager>
<!--配置数据源(连接池)-->
<dataSource type="POOLED">
<!--配置连接数据库的4个基本信息-->
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/test"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<!--指定映射配置文件的位置,映射配置文件指的是每个dao独立的配置文件-->
<mappers>
<mapper resource="top/llllllllll/dao/IUserDao.xml" />
</mappers>
</configuration>
IUserDao.xml如下
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://www.mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="top.llllllllll.dao.IUserDao">
<!--配置查询所有-->
<select id="findAll" resultType="top.llllllllll.domain.User">
select * from user;
</select>
</mapper>
这是编写的测试类
package top.llllllllll.test;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import top.llllllllll.dao.IUserDao;
import top.llllllllll.domain.User;
import java.io.InputStream;
import java.util.List;
/**
* mybatis 的入门案例
*/
public class MbatisTest {
public static void main(String[] args) throws Exception {
//1.读取配置文件
InputStream in = Resources.class.getResourceAsStream("SqlMapConfig.xml");
//2.创建SqlSessionFactory工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(in);
//3.使用工厂生产SqlSession对象
SqlSession session = factory.openSession();
//4.使用SqlSession创建Dao接口的代理对象
IUserDao userdao = session.getMapper(IUserDao.class);
//5.使用代理对象执行方法
List<User> users = userdao.findAll();
for (User user:users) {
System.out.println(user);
}
//6.释放资源
session.close();;
in.close();
}
}
然后就是这一行 SqlSessionFactory factory = builder.build(in); 报空指针。 异常如下
Exception in thread "main" java.lang.NullPointerException
at org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:84)
at org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:64)
at top.llllllllll.test.MbatisTest.main(MbatisTest.java:23)
网上的办法也试过了,有的说把 mybatisTest的这段代码修改一下 InputStream in=Resources.getResourceAsStream(“SqlMapConfig.xml”);
修改为
InputStream in=MybatisTest.class.getResourceAsStream(“SqlMapConfig.xml”);
但是修改之后MybatisTest这个地方报错,还是不行。。。
.
.
.
错误分析:
1.检查一下自己的包是不是这个:
import org.apache.ibatis.io.Resources;
因为有其他很多包,很容易倒错。
2.再回去检查一下读取配置文件的那句
可能因为你之前导错包,去查这句话错误的原因,是加一个class,然后idea也没报错。
InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
加一个class之后:
InputStream in = Resources.class.getResourceAsStream("SqlMapConfig.xml");
结果包正确之后,代码错误。
.
.
正确的应该是这个包
import org.apache.ibatis.io.Resources;
也不需要在Resources之后.class!!!
正确如下:
InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
这个坑希望大家以后多注意啊!