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)的配置,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06mybatis條件構造器(EntityWrapper)的使用方式
這篇文章主要介紹了mybatis條件構造器(EntityWrapper)的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03登錄EasyConnect后無法通過jdbc訪問服務器數據庫問題的解決方法
描述一下近期使用EasyConnect遇到的問題,下面這篇文章主要給大家介紹了關于登錄EasyConnect后無法通過jdbc訪問服務器數據庫問題的解決方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-02-02Springboot關于自定義stater的yml無法提示問題解決方案
這篇文章主要介紹了Springboot關于自定義stater的yml無法提示問題及解決方案,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06