MyBatis插入Insert、InsertSelective的區(qū)別及使用心得
MyBatis插入Insert、InsertSelective的區(qū)別
逆向自動(dòng)生成的mybatis對(duì)應(yīng)配置Mapper文件里面,有兩個(gè)方法,分別為insert和insertSelective。這兩個(gè)方法均是插入對(duì)象的方法。為什么會(huì)有兩個(gè)插入方法呢?
這里說(shuō)一下兩者的區(qū)別
首先我們看代碼如下:
insert方法
<insert id="insert" parameterType="demo.pojo.domain.HspMediaInf" >
insert into MEDIA_INF (MED_SEQ, EMG_SEQ, MED_CLASS,
MED_NAME, MED_FILE, MED_EXTEND,
MED_TYPE, MED_DATE, MED_SIZE,
MED_DATA)
values (#{medSeq,jdbcType=VARCHAR}, #{emgSeq,jdbcType=VARCHAR}, #{medClass,jdbcType=VARCHAR},
#{medName,jdbcType=VARCHAR}, #{medFile,jdbcType=VARCHAR}, #{medExtend,jdbcType=VARCHAR},
#{medType,jdbcType=VARCHAR}, #{medDate,jdbcType=TIMESTAMP}, #{medSize,jdbcType=DECIMAL},
#{medData,jdbcType=BLOB})
</insert>
insertSelective方法
<insert id="insertSelective" parameterType="activetech.zyyhospital.pojo.domain.HspMediaInf" >
insert into HSP_MEDIA_INF
<trim prefix="(" suffix=")" suffixOverrides="," >
<if test="medSeq != null" >
MED_SEQ,
</if>
<if test="emgSeq != null" >
EMG_SEQ,
</if>
<if test="medClass != null" >
MED_CLASS,
</if>
<if test="medName != null" >
MED_NAME,
</if>
<if test="medFile != null" >
MED_FILE,
</if>
<if test="medExtend != null" >
MED_EXTEND,
</if>
<if test="medType != null" >
MED_TYPE,
</if>
<if test="medDate != null" >
MED_DATE,
</if>
<if test="medSize != null" >
MED_SIZE,
</if>
<if test="medData != null" >
MED_DATA,
</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides="," >
<if test="medSeq != null" >
#{medSeq,jdbcType=VARCHAR},
</if>
<if test="emgSeq != null" >
#{emgSeq,jdbcType=VARCHAR},
</if>
<if test="medClass != null" >
#{medClass,jdbcType=VARCHAR},
</if>
<if test="medName != null" >
#{medName,jdbcType=VARCHAR},
</if>
<if test="medFile != null" >
#{medFile,jdbcType=VARCHAR},
</if>
<if test="medExtend != null" >
#{medExtend,jdbcType=VARCHAR},
</if>
<if test="medType != null" >
#{medType,jdbcType=VARCHAR},
</if>
<if test="medDate != null" >
#{medDate,jdbcType=TIMESTAMP},
</if>
<if test="medSize != null" >
#{medSize,jdbcType=DECIMAL},
</if>
<if test="medData != null" >
#{medData,jdbcType=BLOB},
</if>
</trim>
</insert>
從上面連段代碼我們會(huì)發(fā)現(xiàn)insertSelective對(duì)應(yīng)的sql語(yǔ)句加入了NULL校驗(yàn),只會(huì)插入數(shù)據(jù)不為null的字段值。insert則會(huì)插入所有字段,會(huì)插入null。
筆者反思但是為什么會(huì)有這兩種方法呢
總結(jié):由于真實(shí)開發(fā)中,我們?cè)谛薷墓δ艿膄rom表單,或者一個(gè)類的某些模塊編輯的from表單中不會(huì)將所有的數(shù)據(jù)都查詢出來(lái)放到from表單中然后再insert到數(shù)據(jù)庫(kù),所以我們經(jīng)常在這些功能中使用insertSelective方法,此時(shí)只針對(duì)我們操作的屬性進(jìn)行insert操作,而如果使用insert方法,將會(huì)把非表單內(nèi)的內(nèi)容置為null從而影響數(shù)據(jù)安全。
Mybatis選擇插入,選擇更新 Update insert Mapper示例
<update id="updateMethod" parameterType="com.zjl.domain">
update table_name
<set>
<if test="id != null">
id = #{id,jdbcType=BIGINT},
</if>
<if test="creater != null">
creater = #{creater,jdbcType=VARCHAR},
</if>
<if test="modifiedDate != null">
modified_date = #{modifiedDate,jdbcType=TIMESTAMP},
</if>
</set>
where task_id = #{taskId,jdbcType=BIGINT}
</update>
<insert id="insertSelective" parameterType="com.zjl.domain">
insert into table_name
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="id != null">
id,
</if>
<if test="createDate != null">
create_date,
</if>
<if test="modifiedDate != null">
modified_date,
</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null">
#{id,jdbcType=BIGINT},
</if>
<if test="createDate != null">
#{createDate,jdbcType=TIMESTAMP},
</if>
<if test="modifiedDate != null">
#{modifiedDate,jdbcType=TIMESTAMP},
</if>
</trim>
</insert>
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java計(jì)時(shí)新姿勢(shì)StopWatch的使用方法詳解
這篇文章主要給大家介紹了關(guān)于Java計(jì)時(shí)新姿勢(shì)StopWatch的相關(guān)資料,以及java 中使用StopWatch來(lái)計(jì)算時(shí)間差的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-01-01
Mybatis collection查詢集合屬性報(bào)錯(cuò)的解決方案
這篇文章主要介紹了Mybatis collection查詢集合屬性報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
Java網(wǎng)絡(luò)編程UDP實(shí)現(xiàn)消息發(fā)送及聊天
這篇文章主要為大家詳細(xì)介紹了Java網(wǎng)絡(luò)編程UDP實(shí)現(xiàn)消息發(fā)送及聊天,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
Spring中HandlerMethod類源碼詳細(xì)解析
這篇文章主要介紹了Spring中HandlerMethod類源碼詳細(xì)解析,HandlerMethod類用于封裝控制器方法信息,包含類信息、方法Method對(duì)象、參數(shù)、注解等信息,具體的接口請(qǐng)求是可以根據(jù)封裝的信息調(diào)用具體的方法來(lái)執(zhí)行業(yè)務(wù)邏輯,需要的朋友可以參考下2023-11-11
dubbo?filter中有關(guān)bean注入和配置文件讀取方式
這篇文章主要介紹了dubbo?filter中有關(guān)bean注入和配置文件讀取方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05
MyEclipse8.6首次運(yùn)行maven項(xiàng)目圖標(biāo)上沒有小M的標(biāo)識(shí)怎么解決
myeclipse8.6導(dǎo)入maven項(xiàng)目后識(shí)別為普通java項(xiàng)目,即項(xiàng)目圖標(biāo)上沒有小M的標(biāo)識(shí)。這時(shí)是無(wú)法直接運(yùn)行的,怎么解決這一問題呢?下面小編給大家?guī)?lái)了解決方案,需要的朋友參考下吧2016-11-11
Java實(shí)現(xiàn)Excel文件轉(zhuǎn)PDF(無(wú)水印無(wú)限制)
這篇文章主要為大家詳細(xì)介紹了如何利用Java語(yǔ)言實(shí)現(xiàn)Excel文件轉(zhuǎn)PDF的效果,并可以無(wú)水印、無(wú)限制。文中的示例代碼講解詳細(xì),需要的可以參考一下2022-06-06

