亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mybatis動態(tài)拼接實現有條件的插入

 更新時間:2022年02月28日 17:12:41   作者:北漂小白菜  
這篇文章主要介紹了mybatis動態(tài)拼接實現有條件的插入,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

動態(tài)拼接實現有條件的插入

最近在做項目的時候遇到了一個很現實的問題

那就是根據場景不同,然后實現有條件的插入,說穿了就是當這列有數據的時候進行數據的插入,沒有數據的時候自動忽略這列。

其實這些在mybatis的api中有涉及到,但是之前一直沒有好好看,直到最近用到了才認真的看了看這塊的內容。

<!-- 新增部門人員 -->
? ? <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相信就不用多說了,經常用來去空格。這個trim標簽中有三個屬性,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 默認值是:false。
  • 含義:設置是否使用JDBC的getGenereatedKeys方法獲取主鍵并賦值到keyProperty設置的領域模型屬性中。

之前一直以為useGeneratedKeys="true"是讓mysql數據庫主鍵新增,其實是,插入語句后將id賦值給實體bean,即使用insert后,使用bean.getId()可以獲得值,若是false,bean.getId()=null。

不管true還是false,數據庫插入的數據,都會自動生成主鍵(前提是設置自動增長主鍵)。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 使用SpringBoot簡單了解Druid的監(jiān)控系統(tǒng)的配置方法

    使用SpringBoot簡單了解Druid的監(jiān)控系統(tǒng)的配置方法

    這篇文章主要介紹了使用SpringBoot簡單了解Druid的監(jiān)控系統(tǒng)的配置,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • java自定義動態(tài)鏈接數據庫示例

    java自定義動態(tài)鏈接數據庫示例

    這篇文章主要介紹了java自定義動態(tài)鏈接數據庫示例,需要的朋友可以參考下
    2014-02-02
  • Java如何主動從當前線程獲取異常信息

    Java如何主動從當前線程獲取異常信息

    這篇文章主要介紹了Java如何主動從當前線程獲取異常信息,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Java 線程池_動力節(jié)點Java學院整理

    Java 線程池_動力節(jié)點Java學院整理

    系統(tǒng)啟動一個新線程的成本是比較高的,因為它涉及到與操作系統(tǒng)的交互。在這種情況下,使用線程池可以很好的提供性能,尤其是當程序中需要創(chuàng)建大量生存期很短暫的線程時,更應該考慮使用線程池
    2017-05-05
  • java通過url下載文件并輸出的方法

    java通過url下載文件并輸出的方法

    下面小編就為大家分享一篇java通過url下載文件并輸出的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • java結合email實現自動推送功能

    java結合email實現自動推送功能

    這篇文章主要介紹了java結合email實現自動推送功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03
  • 深入探索Java常量池

    深入探索Java常量池

    這篇文章主要介紹了深入探索Java常量池,涉及靜態(tài)常量池和運行時常量池的介紹,常量池的好處,8種基本數據類型的包裝類和常量池等相關內容,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • mybatis條件構造器(EntityWrapper)的使用方式

    mybatis條件構造器(EntityWrapper)的使用方式

    這篇文章主要介紹了mybatis條件構造器(EntityWrapper)的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 登錄EasyConnect后無法通過jdbc訪問服務器數據庫問題的解決方法

    登錄EasyConnect后無法通過jdbc訪問服務器數據庫問題的解決方法

    描述一下近期使用EasyConnect遇到的問題,下面這篇文章主要給大家介紹了關于登錄EasyConnect后無法通過jdbc訪問服務器數據庫問題的解決方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Springboot關于自定義stater的yml無法提示問題解決方案

    Springboot關于自定義stater的yml無法提示問題解決方案

    這篇文章主要介紹了Springboot關于自定義stater的yml無法提示問題及解決方案,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06

最新評論