mybatis开发dao的方法:
1.SqlSessionFactoryBuilder
通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory。
将SqlSessionFactoryBuilder当成一个工具类使用即可,不需要使用单例管理SqlSessionFactoryBuilder
在需要创建SqlSessionFactory时候,只需要new一次SqlSessionFactoryBuilder即可。
2.SqlSessionFactory
通过SqlSessionFactory创建SqlSession,使用单例模式管理sqlSessionFactory(工厂一旦创建,使用一个实例)。
将来mybatis和spring整合后,使用单例模式管理SqlSessionFactory。
3.SqlSession
SqlSession面向用户(程序员)的接口。
SqlSession中提供了很多操作数据库的方法,如:selectOne(返回单个对象)、selectList(返回单个或多个对象)
SqlSession是线程不安全的,在SqlSession实现类中除了有接口中的方法(操作数据库的方法)还有数据域属性。
SqlSession最佳应用场合在方法体内,定义成局部变量使用。
4.原始dao开发方法(程序员需要写dao接口和dao实现类
1.1思路(mapper代理的开发规范):
程序员需要写dao接口和dao实现类。
需要向dao实现类中注入SqlSessionFactory,在方法体内通过SqlSessionFactory创建SqlSession
1.2 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;
}
1.3 dao接口实现类
Public class UserDaoImp implements UserDao {
//需要向dao实现类中注入SqlSessionFactory
//这里通过构造方法注入
Private SqlSessionFactory sqlSessionFactory;
Public UserDaoImp(SqlSessionFactory sqlSessionFactory){
this.sqlSessionFactory = sqlSessionFactory;
}
Public User findUserById(int id) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
User user = sqlSession.selectOne("test.findUserById",id);
return user;
}
<!-- ************************************************************ -->
public void insertUser(User user) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
//执行插入操作
sqlSession.insert("test.insertUser",user);
//提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
<!-- ************************************ -->
public void deleteUser(int id) throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
//执行删除操作
sqlSession.delete("test.deleteUser",id);
//提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
}
1.4:总结原始dao开发问题:
1.dao接口实现类方法中存在大量模板方法,设想能否将这些代码提取出来,大大减轻程序员的工作量。
2.调用sqlsession方法时将statement的id硬编码了。
3.调用sqlsession方法时传入的变量,由于sqlsession方法使用泛型,即使变量类型传入错误,在编译阶段也不报错,不利 于程序员开发。