下面来讨论mybatis开发Dao的方法
先来讲一下基本架构流程中使用到的几个类
1.SqlSession使用范围
1.1SqlSessionFactoryBuilder
经过SqlSessionFactoryBuilder建立会话工厂SqlSessionFactory
将SqlSessionFactoryBuilder当成一个工具类使用便可,不须要使用单例管理SqlSessionFactoryBuilder。
在须要建立SqlSessionFactory时候,只须要new一次SqlSessionFactoryBuilder便可。
1.2 SqlSessionFactory
经过SqlSessionFactory建立SqlSession,使用单例模式管理sqlSessionFactory(工厂一旦建立,使用一个实例)。
未来mybatis和spring整合后,使用单例模式管理sqlSessionFactory。
1.3SqlSession
SqlSession是一个面向用户(程序员)的接口。
SqlSession中提供了不少操做数据库的方法:如:selectOne(返回单个对象)、selectList(返回单个或多个对象)。
SqlSession是线程不安全的,在SqlSesion实现类中除了有接口中的方法(操做数据库的方法)还有数据域属性。
SqlSession最佳应用场合在方法体内,定义成局部变量使用。
接下来就来讲说MyBatis的Dao的写法,分为两种,一种是原始Dao开发方法,一种是mapper代理方法,咱们下面一一讨论:
2.原始dao开发方法(程序员须要写dao接口和dao实现类)
2.1思路:程序员须要写dao接口和dao实现类。
须要向dao实现类中注入SqlSessionFactory,在方法体内经过SqlSessionFactory建立SqlSession。
下面实现Dao的场景是基于以前对用户数据进行增删改查的需求。
2.2写Dao接口java
package cn.edu.hpu.mybatis.dao; import cn.edu.hpu.mybatis.PO.User; //用户管理的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; //修改用户信息 public void updateUser(User user) throws Exception; }
2.3写Dao的实现程序员
package cn.edu.hpu.mybatis.dao; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import cn.edu.hpu.mybatis.PO.User; public class UserDaoImpl implements UserDao{ //须要向dao实现类中注入SqlSessionFactory工厂 //这里咱们暂时没用spring,咱们经过构造方法注入 private SqlSessionFactory sqlSessionFactory; public UserDaoImpl(SqlSessionFactory sqlSessionFactory){ this.sqlSessionFactory=sqlSessionFactory; } @Override public void deleteUser(int id) throws Exception { SqlSession sqlSession=sqlSessionFactory.openSession(); //传入id删除用户 sqlSession.delete("test.deleteUser",id); //提交事务 sqlSession.commit(); sqlSession.close(); } @Override public User findUserById(int id) throws Exception { SqlSession sqlSession=sqlSessionFactory.openSession(); User user=sqlSession.selectOne("test.findUserById",id); //释放资源 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 updateUser(User user) throws Exception { SqlSession sqlSession=sqlSessionFactory.openSession(); sqlSession.update("test.updateUser",user); //提交事务 sqlSession.commit(); sqlSession.close(); } }
测试方法(这里只测试findUserBiId方法):
spring
package cn.edu.hpu.mybatis.test; import java.io.InputStream; 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 cn.edu.hpu.mybatis.PO.User; import cn.edu.hpu.mybatis.dao.UserDao; import cn.edu.hpu.mybatis.dao.UserDaoImpl; public class UserDaoImplTest { private SqlSessionFactory sqlSessionFactory; //注解Before是在执行本类全部测试方法以前先调用这个方法 @Before public void setup() throws Exception{ //建立SqlSessionFactory String resource="SqlMapConfig.xml"; //将配置文件加载成流 InputStream inputStream = Resources.getResourceAsStream(resource); //建立会话工厂,传入mybatis配置文件的信息 sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream); } @Test public void testFindUserById() throws Exception{ //建立Dao对象 UserDao userDao=new UserDaoImpl(sqlSessionFactory); //调用UserDao的方法 User user=userDao.findUserById(1); System.out.println(user.getUsername()); } }
2.4总结原始 dao开发问题sql
一、dao接口实现类方法中存在大量模板方法,设想可否将这些代码提取出来,大大减轻程序员的工做量。
二、调用sqlsession方法时将statement的id硬编码了
三、调用sqlsession方法时传入的变量,因为sqlsession方法使用泛型,即便变量类型传入错误,在编译阶段也不报错,不利于程序员开发。
数据库
下一篇总结咱们来使用mapper代理方法来写Dao,来解决上面咱们发现的问题。apache