mybatis動態(tài)拼接實現(xiàn)有條件的插入
動態(tài)拼接實現(xiàn)有條件的插入
最近在做項目的時候遇到了一個很現(xiàn)實的問題
那就是根據(jù)場景不同,然后實現(xiàn)有條件的插入,說穿了就是當(dāng)這列有數(shù)據(jù)的時候進行數(shù)據(jù)的插入,沒有數(shù)據(jù)的時候自動忽略這列。
其實這些在mybatis的api中有涉及到,但是之前一直沒有好好看,直到最近用到了才認(rèn)真的看了看這塊的內(nèi)容。
<!-- 新增部門人員 --> ? ? <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相信就不用多說了,經(jīng)常用來去空格。這個trim標(biāo)簽中有三個屬性,prefix這個是表明了你要拼接sql的前綴,suffix這個則是表明了動態(tài)sql的后綴,suffixOverrides這個會幫助我去掉最后一個多出來的逗號。
mybatis插入語句
mybatis插入語句一般都是這樣寫
<!-- 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ù)庫主鍵新增,其實是,插入語句后將id賦值給實體bean,即使用insert后,使用bean.getId()可以獲得值,若是false,bean.getId()=null。
不管true還是false,數(shù)據(jù)庫插入的數(shù)據(jù),都會自動生成主鍵(前提是設(shè)置自動增長主鍵)。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用SpringBoot簡單了解Druid的監(jiān)控系統(tǒng)的配置方法
這篇文章主要介紹了使用SpringBoot簡單了解Druid的監(jiān)控系統(tǒng)的配置,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06java自定義動態(tài)鏈接數(shù)據(jù)庫示例
這篇文章主要介紹了java自定義動態(tài)鏈接數(shù)據(jù)庫示例,需要的朋友可以參考下2014-02-02Java 線程池_動力節(jié)點Java學(xué)院整理
系統(tǒng)啟動一個新線程的成本是比較高的,因為它涉及到與操作系統(tǒng)的交互。在這種情況下,使用線程池可以很好的提供性能,尤其是當(dāng)程序中需要創(chuàng)建大量生存期很短暫的線程時,更應(yīng)該考慮使用線程池2017-05-05java結(jié)合email實現(xiàn)自動推送功能
這篇文章主要介紹了java結(jié)合email實現(xiàn)自動推送功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03mybatis條件構(gòu)造器(EntityWrapper)的使用方式
這篇文章主要介紹了mybatis條件構(gòu)造器(EntityWrapper)的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03登錄EasyConnect后無法通過jdbc訪問服務(wù)器數(shù)據(jù)庫問題的解決方法
描述一下近期使用EasyConnect遇到的問題,下面這篇文章主要給大家介紹了關(guān)于登錄EasyConnect后無法通過jdbc訪問服務(wù)器數(shù)據(jù)庫問題的解決方法,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02Springboot關(guān)于自定義stater的yml無法提示問題解決方案
這篇文章主要介紹了Springboot關(guān)于自定義stater的yml無法提示問題及解決方案,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06