使用Mybatis對(duì)數(shù)據(jù)庫(kù)進(jìn)行單表操作的實(shí)現(xiàn)示例
簡(jiǎn)介
該篇文章主要是介紹如何使用MyBatis對(duì)Mysql數(shù)據(jù)庫(kù)進(jìn)行單表操作(對(duì)于mybatis的下載以及配置文件的作用和具體信息,我在上一篇文章中也已經(jīng)提到了),使用的環(huán)境如下:
- JDK版本:1.8
- 編譯器:IDEA2019
- JDBC版本:8.0.18
- mybatis版本:3.5.3
配置文件
首先需要有兩個(gè)配置文件,一個(gè)是configuration.xml文件,配置的是連接數(shù)據(jù)庫(kù)的環(huán)境以及對(duì)于mapper.xml文件的映射,還有另一個(gè)文件就是mapper.xml,這個(gè)文件主要是用來(lái)寫(xiě)sql語(yǔ)句的
configuration.xml文件
<?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="e1">
<environment id="e1">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/bank?serverTimezone=CST"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
<environment id="e2">
<transactionManager type=""></transactionManager>
<dataSource type=""></dataSource>
</environment>
</environments>
<mappers>
<mapper resource="mapper/UserMapper.xml"></mapper>
</mappers>
</configuration>
mapper.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="dao.UserDao">
<insert id="insert">
INSERT ATM VALUES(#{account}, #{password}, #{balance})
</insert>
<update id="update">
update atm set account=#{account},password=#{password},balance=#{balance} where account=#{account};
</update>
<delete id="delete">
DELETE FROM ATM WHERE account=#{account};
</delete>
<select id="selectAll" resultType="domain.User">
SELECT *FROM atm;
</select>
<select id="getTotalCount" resultType="integer">
SELECT COUNT(*) FROM atm;
</select>
<select id="gettotal" resultType="hashmap">
select count(*),max(balance) from atm;
</select>
<select id="selectAllByAcc" resultType="domain.User">
SELECT *FROM atm order by ${flag} ${order};
</select>
</mapper>
具體操作
具體操作看如下代碼,我對(duì)代碼都進(jìn)行了一定的注釋?zhuān)⒔Y(jié)合mapper.xml文件一起看
public class UserDao {
//增加一條記錄,user對(duì)象是我創(chuàng)建的實(shí)體類(lèi)
//mapper.xml文件的sql語(yǔ)句如下:
//update atm set account=#{account},password=#{password},balance=#{balance} where account=#{account};
//#{key}中的key要和實(shí)體類(lèi)user的屬性名一致
//如果傳遞的是基本數(shù)據(jù)類(lèi)型或者String,且#{key}只有一個(gè),那么名字可以不一致
//如果傳入的是map集合,#{key}中的key要和map集合里的key一致
public void insert(User user){
//MYBATIS操作流程
//獲取工廠Builder對(duì)象
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
//獲取configuration.xml配置文件的輸入流
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
//builder根據(jù)is獲取SqlSessionFactory工廠對(duì)象
SqlSessionFactory factory = builder.build(is);
//獲取SqlSession對(duì)象
SqlSession sqlSession = factory.openSession();
//執(zhí)行sql語(yǔ)句操作
//insert是在mapper.xml下,insert標(biāo)簽的id名
//user是我要插入的數(shù)據(jù)(動(dòng)態(tài)操作),替換掉sql語(yǔ)句的#{}
sqlSession.insert("insert", user);
sqlSession.commit();
}
//改:修改記錄,user是要修改的數(shù)據(jù)
//mapper.xml文件的sql語(yǔ)句如下:
//update atm set account=#{account},password=#{password},balance=#{balance} where account=#{account};
public void update(User user){
//MYBATIS操作流程
//獲取工廠Builder對(duì)象
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
//獲取configuration.xml配置文件的輸入流
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
//builder根據(jù)is獲取SqlSessionFactory工廠對(duì)象
SqlSessionFactory factory = builder.build(is);
//獲取SqlSession對(duì)象
SqlSession sqlSession = factory.openSession(true);
//執(zhí)行sql語(yǔ)句操作
sqlSession.update("update",user);
}
//刪除:根據(jù)account刪除
//mapper.xml的sql語(yǔ)句如下:
// DELETE FROM ATM WHERE account=#{account};
public void delete(String account){
//MYBATIS操作流程
//獲取工廠Builder對(duì)象
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
//獲取configuration.xml配置文件的輸入流
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
//builder根據(jù)is獲取SqlSessionFactory工廠對(duì)象
SqlSessionFactory factory = builder.build(is);
//獲取SqlSession對(duì)象
SqlSession sqlSession = factory.openSession(true);
//執(zhí)行sql語(yǔ)句操作
sqlSession.update("delete",account);
}
//===============================查詢====================================
//查詢:查找記錄總條數(shù)以及balance的最大值
//sql語(yǔ)句如下:select count(*),max(balance) from atm;
//select標(biāo)簽上的resultType表示的是返回值,指的是一條記錄的類(lèi)型,最后包裹成list集合
//我這里用的hashMap
public List<Map<String, Object>> gettotal(){
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
SqlSession sqlSession = factory.openSession(true);
return sqlSession.selectList("gettotal");
}
//查詢:獲取總記錄數(shù)
//sql語(yǔ)句: SELECT COUNT(*) FROM atm;
//resultType類(lèi)型:integer
public Integer getTotalCount(){
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
SqlSession sqlSession = factory.openSession(true);
return sqlSession.selectOne("getTotalCount");
}
//查詢:獲取表格的所有記錄
//sql語(yǔ)句:SELECT *FROM atm;
//resultType類(lèi)型:domain.User (如果是自己寫(xiě)的實(shí)體類(lèi),需要類(lèi)名的具體路徑,除非做了配置)
public List<User> selectAll(){
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
SqlSession sqlSession = factory.openSession(true);
return sqlSession.selectList("selectAll");
}
//查詢:查詢所有該表所有記錄,并根據(jù)flag列進(jìn)行order排序
//flag不確定,order可能是升序也可能是降序(由調(diào)用這個(gè)方法的用戶決定)
//sql語(yǔ)句: SELECT *FROM atm order by ${flag} ${order};
//這里用的是${}而不是#{}
//#{}和${}的區(qū)別:
//#{}:當(dāng)我們的動(dòng)態(tài)參數(shù)是用作條件的時(shí)候我們用這個(gè),比如說(shuō)account=#{key}
//${}:當(dāng)我們的動(dòng)態(tài)參數(shù)表示的是一個(gè)普通字符串,比如說(shuō)表名、列名或者關(guān)鍵字我們用這個(gè)
//resultType:domain.User(domain包下的User類(lèi))
public List<User> selectAllByAcc(String flag, String order){
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
SqlSession sqlSession = factory.openSession(true);
Map<String, Object> map = new HashMap<>();
map.put("flag", flag);
map.put("order", order);
return sqlSession.selectList("selectAllByAcc", map);
}
}
關(guān)于單表操作的底層原理
這里我簡(jiǎn)單提一下關(guān)于增刪改查操作的底層原理,以查詢操作為例,查詢操作和增刪改操作的主要區(qū)別在于sql語(yǔ)句的不同以及查詢操作有返回值,所以底層還需要處理返回值
例如:sqlSession.selectOne(sql,obj)
1)首先,底層需要根據(jù)configuration.xml,找到mysql的驅(qū)動(dòng)類(lèi)driver,加載驅(qū)動(dòng)
2)根據(jù)configuration.xml文件,找到連接MySQL數(shù)據(jù)庫(kù)的url,user,password,獲取連接Connection
3)參考configuration.xml配置文件,找到mapper.xml文件,從而找到sql語(yǔ)句,創(chuàng)建狀態(tài)參數(shù)PreparedStatement
4)解析sql語(yǔ)句,把#{key}或者${key}轉(zhuǎn)換成?的形式,并記錄key的名字,根據(jù)傳遞過(guò)來(lái)的obj匹配key,如果傳遞過(guò)來(lái)的是domain實(shí)體對(duì)象,通過(guò)反射獲取domain實(shí)體中的所有屬性,根據(jù)屬性名字去匹配key,然后調(diào)用狀態(tài)參數(shù)的setObject方法對(duì)?進(jìn)行復(fù)制(其他類(lèi)型的對(duì)象也基本如此)
5)執(zhí)行SQL操作,獲取結(jié)果集
6)分析ResultType屬性,獲取返回值類(lèi)型,通過(guò)反射創(chuàng)建對(duì)象,遍歷結(jié)果集,將結(jié)果集包裝成返回值類(lèi)型的對(duì)象
基本的流程大概就是這樣,本篇文章主要是對(duì)單表操作進(jìn)行介紹,下一篇文章會(huì)介紹如果是多表,該如何進(jìn)行操作
到此這篇關(guān)于使用Mybatis對(duì)數(shù)據(jù)庫(kù)進(jìn)行單表操作的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Mybatis 數(shù)據(jù)庫(kù)單表操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從零實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Spring Bean容器的代碼案例
Spring是一個(gè)非常流行的Java?Web開(kāi)發(fā)框架,它提供了強(qiáng)大的依賴注入、面向切面編程、聲明式事務(wù)管理等功能,為開(kāi)發(fā)者提供了高效、快速地構(gòu)建Web應(yīng)用程序的工具,在這篇文章中,咱們將一步一步地構(gòu)建一個(gè)簡(jiǎn)單的SpringBean容器,需要的朋友可以參考下2023-06-06
Java語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單FTP軟件 FTP連接管理模塊實(shí)現(xiàn)(8)
這篇文章主要為大家詳細(xì)介紹了Java語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單FTP軟件,F(xiàn)TP連接管理模塊的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04
關(guān)于Java中static關(guān)鍵字的用法
這篇文章主要介紹了關(guān)于Java中static關(guān)鍵字的用法,static:意為靜態(tài)的,在?Java?里面作為靜態(tài)修飾符,可以理解為全局的意思,static?不僅可以修飾成員變量,成員方法,還可以修飾代碼塊,需要的朋友可以參考下2023-08-08
Java調(diào)用Python腳本傳遞數(shù)據(jù)并返回計(jì)算結(jié)果
實(shí)際工程項(xiàng)目中可能會(huì)用到Java和python兩種語(yǔ)言結(jié)合進(jìn)行,這樣就會(huì)涉及到一個(gè)問(wèn)題,Java如何調(diào)用Python腳本,感興趣的可以了解一下2021-05-05
SpringSecurity 手機(jī)號(hào)登錄功能實(shí)現(xiàn)
這篇文章主要介紹了SpringSecurity 手機(jī)號(hào)登錄功能實(shí)現(xiàn),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2023-12-12

