public class MybatisTest {
/**
* mybatis入门案例
* @param args
*/
public static void main(String[] args) throws IOException {
//1.读取配置文件
InputStream resource = Resources.getResourceAsStream("SqlMapConfig.xml");
//2.创建SqlSessionFactory工厂
//因为SqlSessionFactory 是一个接口 说明无法new出对象 所以找他的实现类来进行创建
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(resource);
//3.使用工厂生成SqlSession
SqlSession sqlSession = factory.openSession();
//4.使用SqlSession创建Dao接口的代理对象
IUserDao mapper = sqlSession.getMapper(IUserDao.class);
//5.使用代理对象执行方法
List<User> all = mapper.findAll();
for (User user : all){
System.out.println(user);
}
//6.释放资源
sqlSession.close();
resource.close();
}
}
1.获取配置文件注意事项
获取配置文件时应该注意使用的方法
1.绝对路径:D:/xxxx/xxxx.xml2.相对路径:src/java/main/xxxx.xml
在项目中只是用两种方式获取配置文件信息
1.使用类加载器,但是它只能获取类路径的配置文件
2.使用ServletContext对象的getRealPath()
这两种方法会避免 项目部署服务器路径导致发生的问题
2.创建SqlSessionFactory工厂
//2.创建SqlSessionFactory工厂
//因为SqlSessionFactory 是一个接口 说明无法new出对象 所以找他的实现类来进行创建
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();//这里没什么好说的
SqlSessionFactory factory = builder.build(resource);//重点!! 构建者模式
这里使用了设计模式中的构建者模式1
我们这里使用的工厂 不是我们自己创建的 而是别人帮我们创建的
比如我们现在要建立一座工厂 我们要考虑
1.工厂的选址
2.工厂所需要的材料
3.预估建立工厂的人员
4.预估需要的时间,金钱等等 一些问题
那么这些问题对于我们来说耗时又耗力 而且最后我们还不一定能做好
那么我们怎么办呢?
我们只需要找一个包工队 那么上面的问题就不需要我们去操心了 我们只需要告诉他
1.我们的需求
2.给钱
//2.创建SqlSessionFactory工厂
//因为SqlSessionFactory 是一个接口 说明无法new出对象 所以找他的实现类来进行创建
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();//这里没什么好说的
SqlSessionFactory factory = builder.build(resource);
//那么这个时候build 就是那个施工队 我们只需要给他钱 其他的细节我们都不需要去操心 我们这是只要使用就可以
构建者模式:把对象的创建细节隐藏,是使用者直接调用方法即可拿到对象。 ↩︎