mybatis教程之增刪改查_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
select
一個(gè)select 元素非常簡(jiǎn)單。例如:
<!-- 查詢(xún)學(xué)生,根據(jù)id --> <select id="getStudent" parameterType="String" resultMap="studentResultMap"> SELECT ST.STUDENT_ID, ST.STUDENT_NAME, ST.STUDENT_SEX, ST.STUDENT_BIRTHDAY, ST.CLASS_ID FROM STUDENT_TBL ST WHERE ST.STUDENT_ID = #{studentID} </select>
這條語(yǔ)句就叫做‘getStudent,有一個(gè)String參數(shù),并返回一個(gè)StudentEntity類(lèi)型的對(duì)象。
注意參數(shù)的標(biāo)識(shí)是:#{studentID}。
select 語(yǔ)句屬性配置細(xì)節(jié):
屬性
|
描述
|
取值
|
默認(rèn)
|
id
|
在這個(gè)模式下唯一的標(biāo)識(shí)符,可被其它語(yǔ)句引用
|
|
|
parameterType
|
傳給此語(yǔ)句的參數(shù)的完整類(lèi)名或別名
|
|
|
resultType
|
語(yǔ)句返回值類(lèi)型的整類(lèi)名或別名。注意,如果是集合,那么這里填寫(xiě)的是集合的項(xiàng)的整類(lèi)名或別名,而不是集合本身的類(lèi)名。(resultType 與resultMap 不能并用)
|
|
|
resultMap
|
引用的外部resultMap 名。結(jié)果集映射是MyBatis 中最強(qiáng)大的特性。許多復(fù)雜的映射都可以輕松解決。(resultType 與resultMap 不能并用)
|
|
|
flushCache
|
如果設(shè)為true,則會(huì)在每次語(yǔ)句調(diào)用的時(shí)候就會(huì)清空緩存。select 語(yǔ)句默認(rèn)設(shè)為false
|
true|false
|
false
|
useCache
|
如果設(shè)為true,則語(yǔ)句的結(jié)果集將被緩存。select 語(yǔ)句默認(rèn)設(shè)為false true|false false
timeout 設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定 |
true|false
|
false
|
timeout
|
設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
|
正整數(shù)
|
未設(shè)置
|
fetchSize
|
設(shè)置一個(gè)值后,驅(qū)動(dòng)器會(huì)在結(jié)果集數(shù)目達(dá)到此數(shù)值后,激發(fā)返回,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
|
正整數(shù)
|
驅(qū)動(dòng)器決定
|
statementType
|
statement,preparedstatement,callablestatement。
預(yù)準(zhǔn)備語(yǔ)句、可調(diào)用語(yǔ)句 |
STATEMENT
PREPARED CALLABLE |
PREPARED
|
resultSetType
|
forward_only,scroll_sensitive,scroll_insensitive
只轉(zhuǎn)發(fā),滾動(dòng)敏感,不區(qū)分大小寫(xiě)的滾動(dòng) |
FORWARD_ONLY
SCROLL_SENSITIVE SCROLL_INSENSITIVE |
驅(qū)動(dòng)器決定
|
insert
一個(gè)簡(jiǎn)單的insert語(yǔ)句:
<!-- 插入學(xué)生 --> <insert id="insertStudent" parameterType="StudentEntity"> INSERT INTO STUDENT_TBL (STUDENT_ID, STUDENT_NAME, STUDENT_SEX, STUDENT_BIRTHDAY, CLASS_ID) VALUES (#{studentID}, #{studentName}, #{studentSex}, #{studentBirthday}, #{classEntityclassID}) </insert>
insert可以使用數(shù)據(jù)庫(kù)支持的自動(dòng)生成主鍵策略,設(shè)置useGeneratedKeys=”true”,然后把keyProperty 設(shè)成對(duì)應(yīng)的列,就搞定了。比如說(shuō)上面的StudentEntity 使用auto-generated 為id 列生成主鍵.
還可以使用selectKey元素。下面例子,使用mysql數(shù)據(jù)庫(kù)nextval('student')為自定義函數(shù),用來(lái)生成一個(gè)key。
<!-- 插入學(xué)生 自動(dòng)主鍵--> <insert id="insertStudentAutoKey" parameterType="StudentEntity"> <selectKey keyProperty="studentID" resultType="String" order="BEFORE"> select nextval('student') </selectKey> INSERT INTO STUDENT_TBL (STUDENT_ID, STUDENT_NAME, STUDENT_SEX, STUDENT_BIRTHDAY, CLASS_ID) VALUES (#{studentID}, #{studentName}, #{studentSex}, #{studentBirthday}, #{classEntityclassID}) </insert>
insert語(yǔ)句屬性配置細(xì)節(jié):
屬性
|
描述
|
取值
|
默認(rèn)
|
id
|
在這個(gè)模式下唯一的標(biāo)識(shí)符,可被其它語(yǔ)句引用
|
|
|
parameterType
|
傳給此語(yǔ)句的參數(shù)的完整類(lèi)名或別名
|
|
|
flushCache
|
如果設(shè)為true,則會(huì)在每次語(yǔ)句調(diào)用的時(shí)候就會(huì)清空緩存。select 語(yǔ)句默認(rèn)設(shè)為false
|
true|false
|
false
|
useCache
|
如果設(shè)為true,則語(yǔ)句的結(jié)果集將被緩存。select 語(yǔ)句默認(rèn)設(shè)為false true|false false
timeout 設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定 |
true|false
|
false
|
timeout
|
設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
|
正整數(shù)
|
未設(shè)置
|
fetchSize
|
設(shè)置一個(gè)值后,驅(qū)動(dòng)器會(huì)在結(jié)果集數(shù)目達(dá)到此數(shù)值后,激發(fā)返回,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
|
正整數(shù)
|
驅(qū)動(dòng)器決定
|
statementType
|
statement,preparedstatement,callablestatement。
預(yù)準(zhǔn)備語(yǔ)句、可調(diào)用語(yǔ)句 |
STATEMENT
PREPARED CALLABLE |
PREPARED
|
useGeneratedKeys
|
告訴MyBatis 使用JDBC 的getGeneratedKeys 方法來(lái)獲取數(shù)據(jù)庫(kù)自己生成的主鍵(MySQL、SQLSERVER 等
關(guān)系型數(shù)據(jù)庫(kù)會(huì)有自動(dòng)生成的字段)。默認(rèn):false
|
true|false
|
false
|
keyProperty
|
標(biāo)識(shí)一個(gè)將要被MyBatis 設(shè)置進(jìn)getGeneratedKeys 的key 所返回的值,或者為insert 語(yǔ)句使用一個(gè)selectKey
子元素。
|
|
selectKey語(yǔ)句屬性配置細(xì)節(jié):
屬性
|
描述
|
取值
|
keyProperty
|
selectKey 語(yǔ)句生成結(jié)果需要設(shè)置的屬性。
|
|
resultType
|
生成結(jié)果類(lèi)型,MyBatis 允許使用基本的數(shù)據(jù)類(lèi)型,包括String 、int類(lèi)型。
|
|
order
|
可以設(shè)成BEFORE 或者AFTER,如果設(shè)為BEFORE,那它會(huì)先選擇主鍵,然后設(shè)置keyProperty,再執(zhí)行insert語(yǔ)句;如果設(shè)為AFTER,它就先運(yùn)行insert 語(yǔ)句再運(yùn)行selectKey 語(yǔ)句,通常是insert 語(yǔ)句中內(nèi)部調(diào)用數(shù)據(jù)庫(kù)(像Oracle)內(nèi)嵌的序列機(jī)制。
|
BEFORE
AFTER |
statementType
|
像上面的那樣, MyBatis 支持STATEMENT,PREPARED和CALLABLE 的語(yǔ)句形式, 對(duì)應(yīng)Statement ,PreparedStatement 和CallableStatement 響應(yīng)
|
STATEMENT
PREPARED CALLABLE |
update、delete
一個(gè)簡(jiǎn)單的update:
<!-- 更新學(xué)生信息 --> <update id="updateStudent" parameterType="StudentEntity"> UPDATE STUDENT_TBL SET STUDENT_TBL.STUDENT_NAME = #{studentName}, STUDENT_TBL.STUDENT_SEX = #{studentSex}, STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday}, STUDENT_TBL.CLASS_ID = #{classEntity.classID} WHERE STUDENT_TBL.STUDENT_ID = #{studentID}; </update>
一個(gè)簡(jiǎn)單的delete:
<!-- 刪除學(xué)生 --> <delete id="deleteStudent" parameterType="StudentEntity"> DELETE FROM STUDENT_TBL WHERE STUDENT_ID = #{studentID} </delete>
update、delete語(yǔ)句屬性配置細(xì)節(jié):
屬性
|
描述
|
取值
|
默認(rèn)
|
id
|
在這個(gè)模式下唯一的標(biāo)識(shí)符,可被其它語(yǔ)句引用
|
|
|
parameterType
|
傳給此語(yǔ)句的參數(shù)的完整類(lèi)名或別名
|
|
|
flushCache
|
如果設(shè)為true,則會(huì)在每次語(yǔ)句調(diào)用的時(shí)候就會(huì)清空緩存。select 語(yǔ)句默認(rèn)設(shè)為false
|
true|false
|
false
|
useCache
|
如果設(shè)為true,則語(yǔ)句的結(jié)果集將被緩存。select 語(yǔ)句默認(rèn)設(shè)為false true|false false
timeout 設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定 |
true|false
|
false
|
timeout
|
設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
|
正整數(shù)
|
未設(shè)置
|
fetchSize
|
設(shè)置一個(gè)值后,驅(qū)動(dòng)器會(huì)在結(jié)果集數(shù)目達(dá)到此數(shù)值后,激發(fā)返回,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
|
正整數(shù)
|
驅(qū)動(dòng)器決定
|
statementType
|
statement,preparedstatement,callablestatement。
預(yù)準(zhǔn)備語(yǔ)句、可調(diào)用語(yǔ)句 |
STATEMENT
PREPARED CALLABLE |
PREPARED
|
sql
Sql元素用來(lái)定義一個(gè)可以復(fù)用的SQL 語(yǔ)句段,供其它語(yǔ)句調(diào)用。比如:
<!-- 復(fù)用sql語(yǔ)句 查詢(xún)student表所有字段 --> <sql id="selectStudentAll"> SELECT ST.STUDENT_ID, ST.STUDENT_NAME, ST.STUDENT_SEX, ST.STUDENT_BIRTHDAY, ST.CLASS_ID FROM STUDENT_TBL ST </sql>
這樣,在select的語(yǔ)句中就可以直接引用使用了,將上面select語(yǔ)句改成:
<!-- 查詢(xún)學(xué)生,根據(jù)id --> <select id="getStudent" parameterType="String" resultMap="studentResultMap"> <include refid="selectStudentAll"/> WHERE ST.STUDENT_ID = #{studentID} </select>
parameters
上面很多地方已經(jīng)用到了參數(shù),比如查詢(xún)、修改、刪除的條件,插入,修改的數(shù)據(jù)等,MyBatis可以使用的基本數(shù)據(jù)類(lèi)型和Java的復(fù)雜數(shù)據(jù)類(lèi)型。
基本數(shù)據(jù)類(lèi)型,String,int,date等。
但是使用基本數(shù)據(jù)類(lèi)型,只能提供一個(gè)參數(shù),所以需要使用Java實(shí)體類(lèi),或Map類(lèi)型做參數(shù)類(lèi)型。通過(guò)#{}可以直接得到其屬性。
基本類(lèi)型參數(shù)
根據(jù)入學(xué)時(shí)間,檢索學(xué)生列表:
<!-- 查詢(xún)學(xué)生list,根據(jù)入學(xué)時(shí)間 --> <select id="getStudentListByDate" parameterType="Date" resultMap="studentResultMap"> SELECT * FROM STUDENT_TBL ST LEFT JOIN CLASS_TBL CT ON ST.CLASS_ID = CT.CLASS_ID WHERE CT.CLASS_YEAR = #{classYear}; </select>
List<StudentEntity> studentList = studentMapper.getStudentListByClassYear(StringUtil.parse("2007-9-1")); for (StudentEntity entityTemp : studentList) { System.out.println(entityTemp.toString()); }
Java實(shí)體類(lèi)型參數(shù)
根據(jù)姓名和性別,檢索學(xué)生列表。使用實(shí)體類(lèi)做參數(shù):
<!-- 查詢(xún)學(xué)生list,like姓名、=性別,參數(shù)entity類(lèi)型 --> <select id="getStudentListWhereEntity" parameterType="StudentEntity" resultMap="studentResultMap"> SELECT * from STUDENT_TBL ST WHERE ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%') AND ST.STUDENT_SEX = #{studentSex} </select>
StudentEntity entity = new StudentEntity(); entity.setStudentName("李"); entity.setStudentSex("男"); List<StudentEntity> studentList = studentMapper.getStudentListWhereEntity(entity); for (StudentEntity entityTemp : studentList) { System.out.println(entityTemp.toString()); }
Map參數(shù)
根據(jù)姓名和性別,檢索學(xué)生列表。使用Map做參數(shù):
<!-- 查詢(xún)學(xué)生list,=性別,參數(shù)map類(lèi)型 --> <select id="getStudentListWhereMap" parameterType="Map" resultMap="studentResultMap"> SELECT * from STUDENT_TBL ST WHERE ST.STUDENT_SEX = #{sex} AND ST.STUDENT_SEX = #{sex} </select>
Map<String, String> map = new HashMap<String, String>(); map.put("sex", "女"); map.put("name", "李"); List<StudentEntity> studentList = studentMapper.getStudentListWhereMap(map); for (StudentEntity entityTemp : studentList) { System.out.println(entityTemp.toString()); }
多參數(shù)的實(shí)現(xiàn)
如果想傳入多個(gè)參數(shù),則需要在接口的參數(shù)上添加@Param注解。給出一個(gè)實(shí)例:
接口寫(xiě)法:
public List<StudentEntity> getStudentListWhereParam(@Param(value = "name") String name, @Param(value = "sex") String sex, @Param(value = "birthday") Date birthdar, @Param(value = "classEntity") ClassEntity classEntity);
SQL寫(xiě)法:
<!-- 查詢(xún)學(xué)生list,like姓名、=性別、=生日、=班級(jí),多參數(shù)方式 --> <select id="getStudentListWhereParam" resultMap="studentResultMap"> SELECT * from STUDENT_TBL ST <where> <if test="name!=null and name!='' "> ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{name}),'%') </if> <if test="sex!= null and sex!= '' "> AND ST.STUDENT_SEX = #{sex} </if> <if test="birthday!=null"> AND ST.STUDENT_BIRTHDAY = #{birthday} </if> <if test="classEntity!=null and classEntityclassID !=null and classEntityclassID!='' "> AND ST.CLASS_ID = #{classEntity.classID} </if> </where> </select>
進(jìn)行查詢(xún):
List<StudentEntity> studentList = studentMapper.getStudentListWhereParam("", "",StringUtil.parse("1985-05-28"), classMapper.getClassByID("20000002")); for (StudentEntity entityTemp : studentList) { System.out.println(entityTemp.toString()); }
字符串代入法
默認(rèn)的情況下,使用#{}語(yǔ)法會(huì)促使MyBatis 生成PreparedStatement 屬性并且使用PreparedStatement 的參數(shù)(=?)來(lái)安全的設(shè)置值。盡量這些是快捷安全,也是經(jīng)常使用的。但有時(shí)候你可能想直接未更改的字符串代入到SQL 語(yǔ)句中。比如說(shuō),對(duì)于ORDER BY,你可能會(huì)這樣使用:ORDER BY ${columnName}但MyBatis 不會(huì)修改和規(guī)避掉這個(gè)字符串。
注意:這樣地接收和應(yīng)用一個(gè)用戶(hù)輸入到未更改的語(yǔ)句中,是非常不安全的。這會(huì)讓用戶(hù)能植入破壞代碼,所以,要么要求字段不要允許客戶(hù)輸入,要么你直接來(lái)檢測(cè)他的合法性 。
cache緩存
MyBatis 包含一個(gè)強(qiáng)在的、可配置、可定制的緩存機(jī)制。MyBatis 3 的緩存實(shí)現(xiàn)有了許多改進(jìn),既強(qiáng)勁也更容易配置。默認(rèn)的情況,緩存是沒(méi)有開(kāi)啟,除了會(huì)話緩存以外,它可以提高性能,且能解決全局依賴(lài)。開(kāi)啟二級(jí)緩存,你只需要在SQL 映射文件中加入簡(jiǎn)單的一行:<cache/>
這句簡(jiǎn)單的語(yǔ)句的作用如下:
1. 所有在映射文件里的select 語(yǔ)句都將被緩存。
2. 所有在映射文件里insert,update 和delete 語(yǔ)句會(huì)清空緩存。
3. 緩存使用“最近很少使用”算法來(lái)回收
4. 緩存不會(huì)被設(shè)定的時(shí)間所清空。
5. 每個(gè)緩存可以存儲(chǔ)1024 個(gè)列表或?qū)ο蟮囊茫ú还懿樵?xún)出來(lái)的結(jié)果是什么)。
6. 緩存將作為“讀/寫(xiě)”緩存,意味著獲取的對(duì)象不是共享的且對(duì)調(diào)用者是安全的。不會(huì)有其它的調(diào)用
7. 者或線程潛在修改。
例如,創(chuàng)建一個(gè)FIFO 緩存讓60 秒就清空一次,存儲(chǔ)512 個(gè)對(duì)象結(jié)果或列表引用,并且返回的結(jié)果是只讀。因?yàn)樵诓挥玫木€程里的兩個(gè)調(diào)用者修改它們可能會(huì)導(dǎo)致引用沖突。
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"> </cache>
還可以在不同的命名空間里共享同一個(gè)緩存配置或者實(shí)例。在這種情況下,你就可以使用cache-ref 來(lái)引用另外一個(gè)緩存。
<cache-ref namespace="com.liming.manager.data.StudentMapper"/>
Cache 語(yǔ)句屬性配置細(xì)節(jié):
屬性
|
說(shuō)明
|
取值
|
默認(rèn)值
|
eviction
|
緩存策略:
LRU - 最近最少使用法:移出最近較長(zhǎng)周期內(nèi)都沒(méi)有被使用的對(duì)象。 FIFI- 先進(jìn)先出:移出隊(duì)列里較早的對(duì)象 SOFT - 軟引用:基于軟引用規(guī)則,使用垃圾回收機(jī)制來(lái)移出對(duì)象 WEAK - 弱引用:基于弱引用規(guī)則,使用垃圾回收機(jī)制來(lái)強(qiáng)制性地移出對(duì)象 |
LRU
FIFI SOFT WEAK |
LRU
|
flushInterval
|
代表一個(gè)合理的毫秒總計(jì)時(shí)間。默認(rèn)是不設(shè)置,因此使用無(wú)間隔清空即只能調(diào)用語(yǔ)句來(lái)清空。
|
正整數(shù)
|
不設(shè)置
|
size
|
緩存的對(duì)象的大小
|
正整數(shù)
|
1024
|
readOnly
|
只讀緩存將對(duì)所有調(diào)用者返回同一個(gè)實(shí)例。因此都不能被修改,這可以極大的提高性能??蓪?xiě)的緩存將通過(guò)序列
化來(lái)返回一個(gè)緩存對(duì)象的拷貝。這會(huì)比較慢,但是比較安全。所以默認(rèn)值是false。
|
true|false
|
false
|
- java連接mongoDB并進(jìn)行增刪改查操作實(shí)例詳解
- mongodb增刪改查詳解_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- Java連接MongoDB進(jìn)行增刪改查的操作
- java jdbc連接mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)增刪改查操作
- Java語(yǔ)言實(shí)現(xiàn)對(duì)MySql數(shù)據(jù)庫(kù)中數(shù)據(jù)的增刪改查操作的代碼
- JavaWeb應(yīng)用實(shí)例:用servlet實(shí)現(xiàn)oracle 基本增刪改查
- java操作mysql實(shí)現(xiàn)增刪改查的方法
- Java連接MySQL數(shù)據(jù)庫(kù)增刪改查的通用方法(推薦)
- java 數(shù)據(jù)庫(kù)連接與增刪改查操作實(shí)例詳解
- java連接Mongodb實(shí)現(xiàn)增刪改查
相關(guān)文章
Java 創(chuàng)建URL的常見(jiàn)問(wèn)題及解決方案
這篇文章主要介紹了Java 創(chuàng)建URL的常見(jiàn)問(wèn)題及解決方案的相關(guān)資料,需要的朋友可以參考下2016-10-10Spring Cloud Gateway實(shí)現(xiàn)灰度發(fā)布方案
灰度發(fā)布是在微服務(wù)中的表現(xiàn)為同一服務(wù)同時(shí)上線不同版本,讓一部分用戶(hù)使用新版本來(lái)驗(yàn)證新特性,如果驗(yàn)證沒(méi)有問(wèn)題,則將所有用戶(hù)都遷移到新版本上,本文就來(lái)介紹一下如何實(shí)現(xiàn),感興趣的可以了解一下2023-12-12SpringBoot整合RabbitMQ實(shí)現(xiàn)延遲隊(duì)列和死信隊(duì)列
RabbitMQ的死信隊(duì)列用于接收其他隊(duì)列中的“死信”消息,所謂“死信”,是指滿足一定條件而無(wú)法被消費(fèi)者正確處理的消息,死信隊(duì)列通常與RabbitMQ的延遲隊(duì)列一起使用,本文給大家介紹了SpringBoot整合RabbitMQ實(shí)現(xiàn)延遲隊(duì)列和死信隊(duì)列,需要的朋友可以參考下2024-06-06MyBatis 動(dòng)態(tài)SQL和緩存機(jī)制實(shí)例詳解
這篇文章主要介紹了MyBatis 動(dòng)態(tài)SQL和緩存機(jī)制實(shí)例詳解,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-09-09java?io文件操作從文件讀取數(shù)據(jù)的六種方法
這篇文章主要為大家介紹了java?io操作總結(jié)從文件讀取數(shù)據(jù)的六種方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-03-03