溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MyBatis如何使用動態(tài)表或列

發(fā)布時間:2021-08-09 10:56:03 來源:億速云 閱讀:257 作者:小新 欄目:編程語言

這篇文章將為大家詳細講解有關(guān)MyBatis如何使用動態(tài)表或列,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

【1】使用預編譯

即,默認值。

<select id="hisNumber" parameterType="hashmap" resultType="hashmap" >
   select number from ${oldTableName} 
<!--這里使用"$"!!!-->
where name=#{name} and date = #{date}
<!--這里使用"#"-->
<select>

預編譯,即首先會生成select number from ? where name=? and date=? 這樣使用”?”作為占位符的語句,然后進行參數(shù)解析。

【2】使用非預編譯

<select id="hisNumber" parameterType="hashmap" resultType="hashmap" statementType="STATEMENT" >
   select number from ${oldTableName} 
<!--這里使用"$"!!!-->
where name='${name,jdbcType=VARCHAR}' and date = '${date,jdbcType=TIMESTAMP}'
<select>

注意后面name和date的取值,使用了'${name}' 格式,這樣會對參數(shù)進行數(shù)據(jù)類型轉(zhuǎn)換,有助于mysql查詢時提升性能。

【3】仍舊使用非預編譯

<select id="hisNumber" parameterType="hashmap" resultType="hashmap" statementType="STATEMENT" >
   select number from ${oldTableName} 
<!--這里使用"$"!!!-->
where name=${name} and date = ${date}
<select>

注意后面name和date的取值,使用了${name} 格式,將會直接取參數(shù)值,不進行數(shù)據(jù)類型轉(zhuǎn)換。當參數(shù)為數(shù)值類型且格式如“00124”時,將會出現(xiàn)數(shù)據(jù)錯讀(會將0124、124等都讀出來)。

故建議使用第一種方式?。?/p>

關(guān)于“MyBatis如何使用動態(tài)表或列”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI