通过上一节的知识整理中我们发现了:
SqlSession是一个面向用户(程序员)的接口。 SqlSession中提供了很多操作数据库的方法:如:selectOne(返回单个对象)、selectList(返回单个或多个对象)。SqlSession是线程不安全的,在SqlSesion实现类中除了有接口中的方法(操作数据库的方法)还有数据域属性。SqlSession最佳应用场合在方法体内,定义成局部变量使用。通过SqlSessionFactory创建SqlSession,使用单例模式管理sqlSessionFactory(工厂一旦创建,使用一个实例)。将来mybatis和spring整合后,使用单例模式管理sqlSessionFactory。将SqlSessionFactoryBuilder当成一个工具类使用即可,不需要使用单例管理SqlSessionFactoryBuilder。 在需要创建SqlSessionFactory时候,只需要new一次SqlSessionFactoryBuilder即可。
在这一节的整理中,我们首先使用原始dao的方法来进行开发。
(UserDao.java)
package com.mybatis.dao;
import com.mybatis.po.User;
/**
* Created by Administrator on 2018/3/29.
* dao用户管理接口
*/
public interface UserDao {
//根据id查询用户信息
public User findUserById(int id) throws Exception;
//添加用户信息
public void insertUser(User user) throws Exception;
//删除用户信息
public void deleteUser(int id) throws Exception;
}
(IUserDaoImpl.java)
package com.mybatis.dao.impl;
import com.mybatis.dao.UserDao;
import com.mybatis.po.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
/**
* Created by Administrator on 2018/3/29.
*/
public class IUserDaoImpl implements UserDao {
//需要向dao实现类中注入SqlSessionFactory
//这里通过构造方法注入
private SqlSessionFactory sqlSessionFactory;
public IUserDaoImpl(SqlSessionFactory sqlSessionFactory){
this.sqlSessionFactory = sqlSessionFactory;
}
@Override
public User findUserById(int id) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
User user= sqlSession.selectOne("test.findUserById",100);
sqlSession.close();;
return user;
}
@Override
public void insertUser(User user) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
sqlSession.insert("test.insertUser",user);
//执行提交事务
sqlSession.commit();
sqlSession.close();
}
@Override
public void deleteUser(int id) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
sqlSession.delete("test.deleteUserById",id);
sqlSession.commit();
sqlSession.close();
}
}
(IUserDaoImplTest.java)
package com.mybatis.test;
import com.mybatis.dao.UserDao;
import com.mybatis.dao.impl.IUserDaoImpl;
import com.mybatis.po.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test;
import java.io.InputStream;
/**
* Created by Administrator on 2018/3/29.
*/
public class IUserDaoImplTest {
SqlSessionFactory sqlSessionFactory;
@Before
public void setUP() throws Exception{
//创建sqlSessionFactory
//mybatis配置文件
String resource ="SqlMapConfig.xml";
// 得到配置文件流
InputStream inputStream= Resources.getResourceAsStream(resource);
//创建回话工厂
sqlSessionFactory =new SqlSessionFactoryBuilder().build(inputStream);
}
@Test
public void testFindUserById() throws Exception {
//创建UserDao的对象
UserDao userDao =new IUserDaoImpl(sqlSessionFactory);
//调用UserDao的方法
User user=userDao.findUserById(100);
System.out.println(user);
}
}