日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

MyBatis 中使用 Mapper 簡化代碼的方法

瀏覽:25日期:2023-10-20 11:08:31

前面文章所寫的增刪改查是存在問題的。每執(zhí)行一次 SQL,都要開啟一次會話,并且需要提交并關(guān)閉,主要問題就是冗余代碼過多,模板化代碼過多。

例如,我想開發(fā)一個 UserDao,可能是下面這樣:

簡化前的 UserDao

public class UserDao { private SqlSessionFactory sqlSessionFactory = SqlSessionFactoryUtils.getInstance(); public User getUserById(Integer id) { SqlSession sqlSession = sqlSessionFactory.openSession(); User user = (User) sqlSession.selectOne('com.antonio.hello.mybatis.mapper.UserDao.getUserById', id); sqlSession.close(); return user; } public Integer addUser(User user) { SqlSession sqlSession = sqlSessionFactory.openSession(); int insert = sqlSession.insert('com.antonio.hello.mybatis.mapper.UserDao.addUser', user); sqlSession.commit(); sqlSession.close(); return insert; } public Integer addUser2(User user) { SqlSession sqlSession = sqlSessionFactory.openSession(); int insert = sqlSession.insert('com.antonio.hello.mybatis.mapper.UserDao.addUser2', user); sqlSession.commit(); sqlSession.close(); return insert; } public Integer deleteUserById(Integer id) { SqlSession sqlSession = sqlSessionFactory.openSession(); int delete = sqlSession.delete('com.antonio.hello.mybatis.mapper.UserDao.deleteUserById', id); sqlSession.commit(); sqlSession.close(); return delete; } public Integer updateUser(User user) { SqlSession sqlSession = sqlSessionFactory.openSession(); int delete = sqlSession.delete('com.antonio.hello.mybatis.mapper.UserDao.updateUser', user); sqlSession.commit(); sqlSession.close(); return delete; } public List<User> getAllUser() { SqlSession sqlSession = sqlSessionFactory.openSession(); List<User> users = sqlSession.selectList('com.antonio.hello.mybatis.mapper.UserDao.getAllUser'); sqlSession.close(); return users; }}

對應(yīng)的 UserMapper.xml

然后,和這個 UserDao 對應(yīng)的,還有一個 UserMapper.xml:

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE mapper PUBLIC '-//mybatis.org//DTD Mapper 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='com.antonio.hello.mybatis.mapper.UserDao'> <select resultType='com.antonio.hello.mybatis.entity.User'> select * from user where id=#{id}; </select> <insert parameterType='com.antonio.hello.mybatis.entity.User'> insert into user (username,address) values (#{username},#{address}); </insert> <insert parameterType='com.antonio.hello.mybatis.entity.User'> <selectKey resultType='java.lang.String' keyProperty='id' order='BEFORE'> select uuid(); </selectKey> insert into user (id,username,address) values (#{id},#{username},#{address}); </insert> <delete parameterType='java.lang.Integer'> delete from user where id=#{id} </delete> <update parameterType='com.antonio.hello.mybatis.entity.User'> update user set username = #{username} where id=#{id}; </update> <select resultType='com.antonio.hello.mybatis.entity.User'> select * from user; </select></mapper>

此時,我們分析這個 UserDao,發(fā)現(xiàn)它有很多可以優(yōu)化的地方。每個方法中都要獲取 SqlSession,涉及到增刪改的方法,還需要 commit,SqlSession 用完之后,還需要關(guān)閉,sqlSession 執(zhí)行時需要的參數(shù)就是方法的參數(shù),sqlSession 要執(zhí)行的 SQL ,和 XML 中的定義是一一對應(yīng)的。這是一個模板化程度很高的代碼。

簡化后的 UserDao

既然模板化程度很高,我們就要去解決它,原理很簡單,就是前面 Spring 中所說的動態(tài)代理。我們可以將 UserDao 簡化成一個接口:

package com.antonio.hello.mybatis.mapper;public interface UserDao { User getUserById(Integer id); Integer addUser(User user); Integer addUser2(User user); Integer deleteUserById(Integer id); Integer updateUser(User user); List<User> getAllUser();}

使用這個接口,完全可以代替上面的 UserDao,為什么呢?因為這個接口提供了 UserDao 所需要的最核心的東西,根據(jù)這個接口,就可以自動生成 UserDao:

首先,UserDao 中定義了 SqlSessionFactory,這是一套固定的代碼 UserMapper 所在的包 + UserMapper 類名 + UserMapper 中定義好的方法名,就可以定位到要調(diào)用的 SQL 要調(diào)用 SqlSession 中的哪個方法,根據(jù)定位到的 SQL 節(jié)點就能確定配置并使用

因此,我們在 MyBatis 開發(fā)中,實際上不需要自己提供 UserDao 的實現(xiàn),我們只需要提供一個 UserMapper 即可。然后,我們在 MyBatis 的全局配置中,配置一下 UserMapper:

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE configuration PUBLIC '-//mybatis.org//DTD Config 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-config.dtd'><configuration> <environments default='development'> <environment id='development'> <transactionManager type='JDBC'/> <dataSource type='POOLED'><property name='driver' value='com.mysql.cj.jdbc.Driver'/><property name='url' value='jdbc:mysql:///test01?serverTimezone=Asia/Shanghai'/><property name='username' value='root'/><property name='password' value='123456'/> </dataSource> </environment> </environments> <mappers> <package name='com.antonio.hello.mybatis.mapper'/> </mappers></configuration>

然后,加載配置文件,獲取 UserMapper,并調(diào)用它里邊的方法:

public class Main2 { public static void main(String[] args) { SqlSessionFactory instance = SqlSessionFactoryUtils.getInstance(); SqlSession sqlSession = instance.openSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); List<User> allUser = mapper.getAllUser(); System.out.println(allUser); }}

注意,在 Maven 中,默認(rèn)情況下,Maven 要求我們將 XML 配置、properties 配置等,都放在 resources 目錄下,如果我們強行放在 java 目錄下,默認(rèn)情況下,打包的時候這個配置文件會被自動忽略掉。對于這兩個問題,我們有兩種解決辦法:

不忽略 XML 配置:

我們可以在 pom.xml 中,添加如下配置,讓 Maven 不要忽略我在 java 目錄下的 XML 配置:

<build> <resources> <resource> <directory>src/main/java</directory> <includes><include>**/*.xml</include> </includes> </resource> <resource> <directory>src/main/resources</directory> </resource> </resources></build>

按照 Maven 的要求來

按照 Maven 的要求來,將 xml 文件放到 resources 目錄下,但是,MyBatis 中默認(rèn)情況下要求,UserMapper.xml 和 UserMapper 接口,必須放在一起,所以,我們需要手動在 resources 目錄下,創(chuàng)建一個和 UserMapper 接口相同的目錄存放 UserMapper.xml。這樣,我們就不需要在 pom.xml 文件中添加配置了,因為這種寫法同時滿足了 Maven 和 MyBatis 的要求。

到此這篇關(guān)于MyBatis 中使用 Mapper 簡化代碼的方法的文章就介紹到這了,更多相關(guān)MyBatis 使用 Mapper 簡化代碼內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
成人在线超碰| 国产精品国产一区| 国产一区日韩欧美| 精品一区三区| 99视频精品| 亚州av日韩av| 你懂的亚洲视频| 国产高清不卡| 国产一区导航| 国产日韩欧美三级| 国产成人久久| 成人日韩在线观看| 国产午夜久久| 久久国产乱子精品免费女| 久久久久九九精品影院| 精品视频自拍| 不卡在线一区| 日韩不卡一区二区| 日韩av自拍| 国产精品日韩欧美一区| 日本久久二区| 天堂中文在线播放| 99re国产精品| 欧美精品aa| 日韩精品一卡| 天堂va在线高清一区| 免费在线亚洲| 99精品网站| 日韩在线观看中文字幕| 精品久久视频| 免费av一区| 亚洲精品第一| 在线天堂中文资源最新版| 免费观看日韩电影| 国产一区二区三区精品在线观看| 日韩午夜电影| 精品久久99| 中文字幕视频精品一区二区三区 | 精品一区二区三区中文字幕在线| av高清一区| 欧美日韩a区| 国产精品88久久久久久| 国产精品自拍区| 欧美日韩少妇| 国产一区二区三区四区五区| 久久不射中文字幕| 成人国产综合| 国产午夜久久av| 香蕉视频成人在线观看| 成人国产精品| 日韩va欧美va亚洲va久久| 久久视频国产| 精品一区二区三区在线观看视频| 蜜桃久久av| 亚洲二区免费| 精品久久电影| 久久狠狠亚洲综合| 一区二区国产在线观看| 欧美13videosex性极品| 国产欧美一级| 亚洲97av| 国产精品三上| 欧美日一区二区| а√在线中文在线新版| 国产精品成人3p一区二区三区| 免费成人在线视频观看| 久久国产影院| 天堂√中文最新版在线| 国产毛片精品| 日本视频一区二区| 亚洲一区二区日韩| 蜜桃tv一区二区三区| 天堂√中文最新版在线| 老鸭窝一区二区久久精品| 综合激情网...| 不卡中文字幕| 国产在线日韩| 免费av一区| 波多野结衣一区| 日韩在线观看不卡| 在线天堂中文资源最新版| 日本一二区不卡| 国产va免费精品观看精品视频| 久久国产乱子精品免费女| 欧美一区成人| 国产欧美日韩亚洲一区二区三区| 水野朝阳av一区二区三区| 婷婷中文字幕一区| 99精品电影| 久久九九99| 欧美搞黄网站| 国产亚洲永久域名| 蜜臀精品久久久久久蜜臀 | 91精品国产乱码久久久久久久| 最近高清中文在线字幕在线观看1| 国产一区二区亚洲| 国产中文在线播放| 精品三级久久| 91九色精品| 亚洲一卡久久| 偷拍亚洲精品| 欧美视频久久| 国产精品久久久久9999高清| 国产欧美一级| 精品国产乱码久久久| 高清在线一区| 欧美中文字幕一区二区| 尤物在线精品| 日本不卡的三区四区五区| 青青草国产成人99久久| 欧美成人aaa| 久久久久久美女精品| 亚洲综合不卡| 日韩av一区二区在线影视| 久久a爱视频| 日韩伦理一区| 最新日韩av| 亚洲精品日本| 国产精品一区三区在线观看| 成人精品高清在线视频| 国产精品7m凸凹视频分类| 亚洲一二av| 激情中国色综合| 成人av二区| 欧美日韩夜夜| 91精品在线观看国产| 亚洲久草在线| 久久亚洲黄色| 91成人精品| 日韩精品久久理论片| 老鸭窝一区二区久久精品| 久久亚洲成人| 日韩美女精品| 日韩1区2区| 久久国产99| www在线观看黄色| 久久国产免费看| 免费精品一区| 最近国产精品视频| 精品一区二区三区中文字幕 | 日韩精品视频一区二区三区| 精品日韩一区| 午夜国产精品视频| 国产精品一线天粉嫩av| 久久精品一区二区不卡| 日本h片久久| 国产精品精品| 午夜亚洲福利| 日韩久久视频| 欧美一区成人| 亚洲精品在线观看91| 国产精品视频首页| 影音先锋国产精品| 粉嫩av一区二区三区四区五区| 丝袜a∨在线一区二区三区不卡| 欧美激情aⅴ一区二区三区| 欧美 日韩 国产精品免费观看| 国产精品自拍区| 性一交一乱一区二区洋洋av| 91亚洲国产| 国产伦精品一区二区三区视频 | 婷婷成人在线| 模特精品在线| 国产三级一区| 亚洲精品乱码| 97精品国产一区二区三区 | 久久精品青草| 久久精品国产999大香线蕉 | 亚洲黄色影院| 在线亚洲人成| 亚洲精品在线国产| 亚洲黄色网址| 国产精品红桃| 亚洲精一区二区三区| 亚洲午夜av| 国产日韩电影| 美女视频免费精品| 麻豆亚洲精品| 91精品成人| 91精品亚洲| 亚洲风情在线资源| 久久不卡日韩美女| 日韩国产一区二| 日韩专区欧美专区| 亚洲女同一区| 少妇精品导航| 欧美一区久久久| 久久精品国产精品亚洲毛片| 日韩精品导航| 久热综合在线亚洲精品| 欧美精品一区二区久久| 亚洲精品**中文毛片| 国内不卡的一区二区三区中文字幕| 欧美欧美黄在线二区| 日本在线不卡视频一二三区| 老司机精品久久| 亚洲在线一区| 欧美美女一区| 国产日产精品_国产精品毛片 | 国产超碰精品|