mybatis動(dòng)態(tài)拼接實(shí)現(xiàn)有條件的插入
動(dòng)態(tài)拼接實(shí)現(xiàn)有條件的插入
最近在做項(xiàng)目的時(shí)候遇到了一個(gè)很現(xiàn)實(shí)的問(wèn)題
那就是根據(jù)場(chǎng)景不同,然后實(shí)現(xiàn)有條件的插入,說(shuō)穿了就是當(dāng)這列有數(shù)據(jù)的時(shí)候進(jìn)行數(shù)據(jù)的插入,沒(méi)有數(shù)據(jù)的時(shí)候自動(dòng)忽略這列。
其實(shí)這些在mybatis的api中有涉及到,但是之前一直沒(méi)有好好看,直到最近用到了才認(rèn)真的看了看這塊的內(nèi)容。
<!-- 新增部門(mén)人員 -->
? ? <insert id="addStaffForApp" parameterType="com.hivescm.org.dto.StaffForAppDto" >
? ? ? ? insert into base_department_staff
? ? ? ? <trim prefix="(" suffix=")" suffixOverrides="," >
? ? ? ? ? ? status,
? ? ? ? ? ? group_id,
? ? ? ? ? ? staff_code,
? ? ? ? ? ? realname,
? ? ? ? ? ? create_time,
? ? ? ? ? ? phone,
? ? ? ? ? ? is_temporary
? ? ? ? ? ? <if test="param.email !=null">
? ? ? ? ? ? ? ? email,
? ? ? ? ? ? </if>
? ? ? ? ? ? <if test="param.userId !=null">
? ? ? ? ? ? ? ? user_id,
? ? ? ? ? ? </if>
? ? ? ? ? ? <if test="param.sex !=null">
? ? ? ? ? ? ? ? sex,
? ? ? ? ? ? </if>
? ? ? ? </trim>
?
? ? ? ? <trim prefix="values (" suffix=")" suffixOverrides="," >
? ? ? ? ? ? #{param.status},
? ? ? ? ? ? #{param.groupId},
? ? ? ? ? ? #{param.staffCode},
? ? ? ? ? ? #{param.realname},
? ? ? ? ? ? #{param.phone},
? ? ? ? ? ? #{param.temporary}
? ? ? ? ? ? <if test="param.email !=null">#{param.email},
? ? ? ? ? ? </if>
? ? ? ? ? ? <if test="param.userId !=null">#{param.userId},
? ? ? ? ? ? </if>
? ? ? ? ? ? <if test="param.sex !=null">#{param.sex},
? ? ? ? ? ? </if>
? ? ? ?</trim>
? ? </insert>這里頭的trim相信就不用多說(shuō)了,經(jīng)常用來(lái)去空格。這個(gè)trim標(biāo)簽中有三個(gè)屬性,prefix這個(gè)是表明了你要拼接sql的前綴,suffix這個(gè)則是表明了動(dòng)態(tài)sql的后綴,suffixOverrides這個(gè)會(huì)幫助我去掉最后一個(gè)多出來(lái)的逗號(hào)。
mybatis插入語(yǔ)句
mybatis插入語(yǔ)句一般都是這樣寫(xiě)
<!-- useGeneratedKeys="true"把新增加的主鍵賦值到自己定義的keyProperty(id)中 -->
<insert id="insert" parameterType="xxx.xxx.xxx.xxx" keyProperty="id" useGeneratedKeys="true">
useGeneratedKeys取值范圍true|false 默認(rèn)值是:false。- 含義:設(shè)置是否使用JDBC的getGenereatedKeys方法獲取主鍵并賦值到keyProperty設(shè)置的領(lǐng)域模型屬性中。
之前一直以為useGeneratedKeys="true"是讓mysql數(shù)據(jù)庫(kù)主鍵新增,其實(shí)是,插入語(yǔ)句后將id賦值給實(shí)體bean,即使用insert后,使用bean.getId()可以獲得值,若是false,bean.getId()=null。
不管true還是false,數(shù)據(jù)庫(kù)插入的數(shù)據(jù),都會(huì)自動(dòng)生成主鍵(前提是設(shè)置自動(dòng)增長(zhǎng)主鍵)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Maven的國(guó)內(nèi)鏡像(快速解決jar下載過(guò)慢的問(wèn)題)
下面小編就為大家?guī)?lái)一篇Maven的國(guó)內(nèi)鏡像(快速解決jar下載過(guò)慢的問(wèn)題)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06
Mybatis返回單個(gè)實(shí)體或者返回List的實(shí)現(xiàn)
這篇文章主要介紹了Mybatis返回單個(gè)實(shí)體或者返回List的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
使用HttpClient調(diào)用接口的實(shí)例講解
下面小編就為大家?guī)?lái)一篇使用HttpClient調(diào)用接口的實(shí)例講解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
用Spring將Service注入到Servlet中的流程步驟
在Java Web開(kāi)發(fā)中,??Servlet??是一個(gè)非常重要的組件,它用于處理客戶端的請(qǐng)求并生成響應(yīng),而?Spring??框架則是一個(gè)廣泛使用的依賴(lài)注入框架,可以幫助開(kāi)發(fā)者管理應(yīng)用中的對(duì)象及其依賴(lài)關(guān)系,本文將介紹如何使用Spring框架將Service層的對(duì)象注入到Servlet中2025-01-01
Java實(shí)現(xiàn)規(guī)則幾何圖形的繪制與周長(zhǎng)面積計(jì)算詳解
隨著計(jì)算機(jī)的發(fā)展,人們對(duì)圖形的計(jì)算要求會(huì)越來(lái)越高。在各行各業(yè)中的計(jì)算人員會(huì)對(duì)圖形的計(jì)算要有便利的要求,規(guī)則幾何圖形問(wèn)題求解程序應(yīng)運(yùn)而生!本文將用Java編寫(xiě)一個(gè)程序,可以實(shí)現(xiàn)規(guī)則幾何圖形的繪制與周長(zhǎng)面積計(jì)算,感興趣的可以了解一下2022-07-07
SpringBoot整合第三方技術(shù)的實(shí)現(xiàn)
本文主要介紹了SpringBoot整合第三方技術(shù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02

