本篇文章為大家展示了使用MyBatis如何實現(xiàn)Dao開發(fā),內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
1.SqlSession使用范圍
1.1 SqlsessionFactoryBuilder
通過SqlSessionFactoryBuilder創(chuàng)建會話工廠SqlSessionFactory,將SqlSessionFactoryBuilder當成一個工具類使用即可,不需要使用單例管理SqlSessionFactoryBuilder。
在需要創(chuàng)建SqlSessionFactory時候,只需要new一次SqlSessionFactoryBuilder即可。
1.2 SqlsessionFactory
通過SqlSessionFactory創(chuàng)建SqlSession,使用單例模式管理SqlSessionFactory(工廠一旦創(chuàng)建,使用一個實例)。
將來MyBatis和Spring整合后,使用單例模式管理SqlSessionFactory。
1.3 SqlSession
SqlSession是一個面向用戶(程序員)的接口。
SqlSession提供了很多操作數(shù)據(jù)庫的方法,如:selectOne(返回單個對象)、selectList(返回單個或多個對象)。
SqlSession是線程不安全的,在SqlSession實現(xiàn)類中除了有接口中的方法(操作數(shù)據(jù)庫的方法)還有數(shù)據(jù)域屬性。
SqlSession最佳應用場合在方法體內(nèi),定義成局部變量使用。
2.原始dao開發(fā)方法(程序員需要寫dao接口和dao實現(xiàn)類)
2.1 思路
程序員需要寫dao接口和dao實現(xiàn)類。
需要向dao的實現(xiàn)類中注入SqlSessionFactory,在方法體內(nèi)通過SqlSessionFactory創(chuàng)建SqlSession.
2.2 dao接口
public interface UserDao { //根據(jù)id查詢用戶信息 public User findUserById(int id) throws Exception; //添加用戶信息 public void insertUser(User user) throws Exception; //刪除用戶信息 public void deleteUser(int id) throws Exception; }