簡(jiǎn)單了解java ibatis #及$的區(qū)別和用法
1、#和$兩者含義不同
#:會(huì)進(jìn)行預(yù)編譯,而且進(jìn)行類型匹配;
$:不進(jìn)行數(shù)據(jù)類型匹配。
示例:變量name的類型是string, 值是'張三'
$name$ = 張三#name# =’張三’
因此使用$就會(huì)報(bào)錯(cuò),若要使用$的話,需要修改為’$name$’;
2、兩者的實(shí)現(xiàn)方式不同
2.1)$ 作用相等于是字符串拼接,
select * from users where name= $name$
等效于
StringBuffer sb = newStringBuffer(256);sb.append('select * from users where name=').append(name);sb.toString();
2.2)# 作用相當(dāng)于變量替換
select * from users where name = #name#
等效于
prepareStement=stmt.createPrepareStement('select * from users where name = ?')prepareStement.setString(1,’張三’);//自動(dòng)進(jìn)行java類型和jdbc類型轉(zhuǎn)換
3、#和$使用場(chǎng)景不同
3.1)變量的傳遞,必須使用#。可以防止sql注入,#是用prepareStement,提示效率
#方式一般用于傳入添加/修改的值或查詢/刪除的where條件
3.2)$只是簡(jiǎn)單的字符拼接而已,對(duì)于非變量部分,那只能使用$,實(shí)際上,在很多場(chǎng)合,$也是有很多實(shí)際意義的
$方式一般用于傳入數(shù)據(jù)庫(kù)對(duì)象(如傳入表名)
例如:
select * from $tableName$ 對(duì)于不同的表執(zhí)行統(tǒng)一的查詢 update $tableName$ set name = #name# 每個(gè)實(shí)體一張表,改變不用實(shí)體的狀態(tài)特別說(shuō)明,$只是字符串拼接,所以要特別小心sql注入問(wèn)題。
3.3)能同時(shí)使用#和$的時(shí)候,最好用#
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. HTML <!DOCTYPE> 標(biāo)簽2. CSS代碼檢查工具stylelint的使用方法詳解3. 如何在CSS中繪制曲線圖形及展示動(dòng)畫(huà)4. msxml3.dll 錯(cuò)誤 800c0019 系統(tǒng)錯(cuò)誤:-2146697191解決方法5. 告別AJAX實(shí)現(xiàn)無(wú)刷新提交表單6. HTML中的XML數(shù)據(jù)島記錄編輯與添加7. 5個(gè)HTML5的常用本地存儲(chǔ)方式詳解與介紹8. asp在iis7報(bào)錯(cuò)行號(hào)不準(zhǔn)問(wèn)題的解決方法9. 三個(gè)不常見(jiàn)的 HTML5 實(shí)用新特性簡(jiǎn)介10. 原生js XMLhttprequest請(qǐng)求onreadystatechange執(zhí)行兩次的解決
