Mybatis学习记录(二)----mybatis开发dao的方法
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中提供了很多操作數據庫的方法:如:selectOne(返回單個對象)、selectList(返回單個或多個對象)、。
SqlSession是線程不安全的,在SqlSesion實現類中除了有接口中的方法(操作數據庫的方法)還有數據域屬性。
SqlSession最佳應用場合在方法體內,定義成局部變量使用。
2? 原始dao開發(fā)方法(程序員需要寫dao接口和dao實現類)
2.1 思路
程序員需要寫dao接口和dao實現類。
需要向dao實現類中注入SqlSessionFactory,在方法體內通過SqlSessionFactory創(chuàng)建SqlSession
2.2 dao接口
2.3 dao接口實現類
package com.joe.mybatis.dao.impl;import java.util.List;import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory;import com.joe.mybatis.dao.UserDao; import com.joe.mybatis.entities.User;public class UserDaoImpl implements UserDao {// 需要向Dao實現類注入SqlSessionFactory// 這里通過構造方法注入private SqlSessionFactory sqlSessionFactory;public UserDaoImpl(SqlSessionFactory sqlSessionFactory) {this.sqlSessionFactory = sqlSessionFactory;}/** <非doc 標簽> Title: findUserById Description: 通過Id查詢用戶信息* * @param id* * @return* * @throws Exception* * @see com.joe.mybatis.dao.UserDao#findUserById(int)*/@Overridepublic User findUserById(int id) throws Exception {SqlSession sqlSession = sqlSessionFactory.openSession();// 查詢數據User user = sqlSession.selectOne("test.findUserById", id);// 釋放資源 sqlSession.close();return user;}/* *<非doc 標簽>* Title: findUserByName* Description: TODO 父類方法描述* @param name* @return* @throws Exception * @see com.joe.mybatis.dao.UserDao#findUserByName(java.lang.String) */@Overridepublic List<User> findUserByName(String name) throws Exception {// TODO Auto-generated method stubSqlSession sqlSession = sqlSessionFactory.openSession();// 查詢數據List<User> list = sqlSession.selectList("test.findUserByName", name);// 釋放資源 sqlSession.close();return list;}/** <非doc 標簽> Title: insertUser Description: 添加用戶信息* * @param user* * @throws Exception* * @see* com.joe.mybatis.dao.UserDao#insertUser(com.joe.mybatis.entities.User)*/@Overridepublic void insertUser(User user) throws Exception {SqlSession sqlSession = sqlSessionFactory.openSession();// 查詢數據sqlSession.insert("test.insertUser", user);// 提交事務 sqlSession.commit();// 釋放資源 sqlSession.close();}/** <非doc 標簽> Title: deleteUser Description: TODO 父類方法描述* * @param id* * @throws Exception* * @see com.joe.mybatis.dao.UserDao#deleteUser(int)*/@Overridepublic void deleteUser(int id) throws Exception {// TODO Auto-generated method stubSqlSession sqlSession = sqlSessionFactory.openSession();// 查詢數據sqlSession.delete("test.deleteUser", id);// 提交事務 sqlSession.commit();// 釋放資源 sqlSession.close();}}2.4 測試代碼:
2.5 總結原始 dao開發(fā)問題
- dao接口實現類方法中存在大量模板方法,設想能否將這些代碼提取出來,大大減輕程序員的工作量。
- 調用sqlsession方法時將statement的id硬編碼了
- 調用sqlsession方法時傳入的變量,由于sqlsession方法使用泛型,即使變量類型傳入錯誤,在編譯階段也不報錯,不利于程序員開發(fā)。
3? mapper代理方法(程序員只需要mapper接口(相當 于dao接口))
3.1 思路(mapper代理開發(fā)規(guī)范)
程序員還需要編寫mapper.xml映射文件
程序員編寫mapper接口需要遵循一些開發(fā)規(guī)范,mybatis可以自動生成mapper接口實現類代理對象。
開發(fā)規(guī)范:
- 在mapper.xml中namespace等于mapper接口地址
- mapper.java接口中的方法名和mapper.xml中statement的id一致
- mapper.java接口中的方法輸入參數類型和mapper.xml中statement的parameterType指定的類型一致。
- mapper.java接口中的方法返回值類型和mapper.xml中statement的resultType指定的類型一致。
總結:
以上開發(fā)規(guī)范主要是對下邊的代碼進行統(tǒng)一生成:
User user = sqlSession.selectOne("test.findUserById", id);
sqlSession.insert("test.insertUser", user);
。。。。
3.2 mapper.java
3.3 mapper.xml
3.4 在SqlMapConfig.xml中加載mapper.xml
3.5 測試
3.6 一些問題總結
- 代理對象內部調用selectOne或selectList
如果mapper方法返回單個pojo對象(非集合對象),代理對象內部通過selectOne查詢數據庫。
如果mapper方法返回集合對象,代理對象內部通過selectList查詢數據庫。
- mapper接口方法參數只能有一個是否影響系統(tǒng) 開發(fā)
mapper接口方法參數只能有一個,系統(tǒng)是否不利于擴展維護。
系統(tǒng) 框架中,dao層的代碼是被業(yè)務層公用的。
即使mapper接口只有一個參數,可以使用包裝類型的pojo滿足不同的業(yè)務方法的需求。
注意:持久層方法的參數可以包裝類型、map。。。,service方法中建議不要使用包裝類型(不利于業(yè)務層的可擴展)。
轉載于:https://www.cnblogs.com/doctorJoe/p/5279155.html
總結
以上是生活随笔為你收集整理的Mybatis学习记录(二)----mybatis开发dao的方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 国六b对汽车有什么影响呢?
- 下一篇: NOIP2012普及组 (四年后的)解题