日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Mybatis学习记录(二)----mybatis开发dao的方法

發布時間:2025/5/22 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Mybatis学习记录(二)----mybatis开发dao的方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1? SqlSession使用范圍

1.1 SqlSessionFactoryBuilder

通過SqlSessionFactoryBuilder創建會話工廠SqlSessionFactory

將SqlSessionFactoryBuilder當成一個工具類使用即可,不需要使用單例管理SqlSessionFactoryBuilder。

在需要創建SqlSessionFactory時候,只需要new一次SqlSessionFactoryBuilder即可。

1.2 SqlSessionFactory

通過SqlSessionFactory創建SqlSession,使用單例模式管理sqlSessionFactory(工廠一旦創建,使用一個實例)。

將來mybatis和spring整合后,使用單例模式管理sqlSessionFactory。

1.3 SqlSession

SqlSession是一個面向用戶(程序員)的接口。

SqlSession中提供了很多操作數據庫的方法:如:selectOne(返回單個對象)、selectList(返回單個或多個對象)、。

SqlSession是線程不安全的,在SqlSesion實現類中除了有接口中的方法(操作數據庫的方法)還有數據域屬性。

SqlSession最佳應用場合在方法體內,定義成局部變量使用。

2? 原始dao開發方法(程序員需要寫dao接口和dao實現類)

2.1 思路

程序員需要寫dao接口和dao實現類。

需要向dao實現類中注入SqlSessionFactory,在方法體內通過SqlSessionFactory創建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開發問題

  • dao接口實現類方法中存在大量模板方法,設想能否將這些代碼提取出來,大大減輕程序員的工作量。
  • 調用sqlsession方法時將statement的id硬編碼了
  • 調用sqlsession方法時傳入的變量,由于sqlsession方法使用泛型,即使變量類型傳入錯誤,在編譯階段也不報錯,不利于程序員開發。

3? mapper代理方法(程序員只需要mapper接口(相當 于dao接口))

3.1 思路(mapper代理開發規范)

程序員還需要編寫mapper.xml映射文件

程序員編寫mapper接口需要遵循一些開發規范,mybatis可以自動生成mapper接口實現類代理對象。

開發規范:

  • 在mapper.xml中namespace等于mapper接口地址

  • mapper.java接口中的方法名和mapper.xml中statement的id一致
  • mapper.java接口中的方法輸入參數類型和mapper.xml中statement的parameterType指定的類型一致。
  • mapper.java接口中的方法返回值類型和mapper.xml中statement的resultType指定的類型一致。

總結:

以上開發規范主要是對下邊的代碼進行統一生成:

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接口方法參數只能有一個是否影響系統 開發

mapper接口方法參數只能有一個,系統是否不利于擴展維護。

系統 框架中,dao層的代碼是被業務層公用的。

即使mapper接口只有一個參數,可以使用包裝類型的pojo滿足不同的業務方法的需求。

注意:持久層方法的參數可以包裝類型、map。。。,service方法中建議不要使用包裝類型(不利于業務層的可擴展)。

轉載于:https://www.cnblogs.com/doctorJoe/p/5279155.html

總結

以上是生活随笔為你收集整理的Mybatis学习记录(二)----mybatis开发dao的方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国内自拍第二页 | 日韩欧美高清在线 | 免费看大片a| 中文字幕综合网 | 欧美亚州 | 国产午夜三级一区二区三 | 一级丰满大乳hd高清 | 成人av网站免费 | www.一区二区三区四区 | 久久国| 亚洲美免无码中文字幕在线 | 日韩电影在线观看中文字幕 | 午夜国产一区二区 | 可以直接看的毛片 | 七仙女欲春2一级裸体片 | 亚洲免费一区二区 | 亚洲国产精品成人综合在线 | 亚洲a级片 | 麻豆精品国产传媒av | 在线播放精品视频 | 日本美女黄色大片 | a级国产视频 | 中国在线观看免费视频 | 国产欧美另类 | 可以免费看毛片的网站 | 人人澡人人射 | 秋霞影院午夜伦 | 刘亦菲久久免费一区二区 | 91精品一区二区 | 九九久久国产视频 | 久久精品三级视频 | 欧美一区二区三区网站 | 亚洲视频91 | 国产精品hd | 99精品国产一区二区 | 福利电影一区二区三区 | www.99色 | 伊人逼逼| 麻豆视频传媒入口 | 精品视频网站 | 视频在线观看电影完整版高清免费 | 91人人干| 蜜桃av噜噜一区二区三区 | 少妇一边呻吟一边说使劲视频 | 日本激情久久 | 中国二级毛片 | 武林美妇肉伦娇喘呻吟 | 影音先锋亚洲资源 | 欧美综合自拍 | 高h视频在线免费观看 | 淫语对白| 3p视频在线观看 | 看污网站| 亚洲综人 | 国产成人99 | 亚洲夜色 | 成人无高清96免费 | wwwww在线观看 | 亚洲精品在线观看免费 | 毛片无码免费无码播放 | 日韩www在线观看 | 国产suv精品一区 | 97网站 | 天天干免费视频 | 亚洲精品乱码久久久久久 | 亚洲免费大片 | www五月天com | 69久久久久| 色婷五月天 | 免费在线观看高清影视网站 | 成人手机在线观看 | 美女让男人捅 | 亚洲精品一线 | 日本免费黄色大片 | 天天骑夜夜操 | 亚洲av无码乱码在线观看富二代 | 日韩黄色精品视频 | 免费看成人片 | 国产精品无码专区av免费播放 | 波多野结衣在线视频免费观看 | 日本少妇videos高潮 | 国产小视频你懂的 | 又紧又大又爽精品一区二区 | 新红楼梦2005锦江版高清在线观看 | 色婷婷视频 | 合欢视频污 | 国产高潮国产高潮久久久91 | 亚洲av无码久久精品狠狠爱浪潮 | 中国国产bdsm紧缚捆绑 | 欧美毛片视频 | 欧美成人aaaa | 国产一二三区在线 | 使劲插视频 | 亚洲17p | 熟妇人妻中文字幕 | 亚洲靠逼| 神宫寺奈绪一区二区三区 | 成人免费一区二区三区在线观看 | 传媒av在线 |