簡單了解java ibatis #及$的區(qū)別和用法
1、#和$兩者含義不同
#:會進(jìn)行預(yù)編譯,而且進(jìn)行類型匹配;
$:不進(jìn)行數(shù)據(jù)類型匹配。
示例:變量name的類型是string, 值是"張三"
$name$ = 張三
#name# ='張三'
因此使用$就會報錯,若要使用$的話,需要修改為'$name$';
2、兩者的實現(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,'張三');//自動進(jìn)行java類型和jdbc類型轉(zhuǎn)換
3、#和$使用場景不同
3.1)變量的傳遞,必須使用#??梢苑乐箂ql注入,#是用prepareStement,提示效率
#方式一般用于傳入添加/修改的值或查詢/刪除的where條件
3.2)$只是簡單的字符拼接而已,對于非變量部分,那只能使用$,實際上,在很多場合,$也是有很多實際意義的
$方式一般用于傳入數(shù)據(jù)庫對象(如傳入表名)
例如:
- select * from $tableName$ 對于不同的表執(zhí)行統(tǒng)一的查詢
- update $tableName$ set name = #name# 每個實體一張表,改變不用實體的狀態(tài)
特別說明,$只是字符串拼接,所以要特別小心sql注入問題。
3.3)能同時使用#和$的時候,最好用#
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring?Security圖形驗證碼的實現(xiàn)代碼
本文介紹了如何在SpringSecurity自定義認(rèn)證中添加圖形驗證碼,首先需要在maven中添加相關(guān)依賴并創(chuàng)建驗證碼對象,然后通過Spring的HttpSessionSessionStrategy對象將驗證碼存儲到Session中,感興趣的朋友跟隨小編一起看看吧2024-10-10springboot+thymeleaf打包成jar后找不到靜態(tài)資源的坑及解決
這篇文章主要介紹了springboot+thymeleaf打包成jar后找不到靜態(tài)資源的坑及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11SpringBoot使用Sa-Token實現(xiàn)路徑攔截和特定接口放行
這篇文章主要介紹了SpringBoot使用Sa-Token實現(xiàn)路徑攔截和特定接口放行,文中通過代碼示例講解的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-06-06IDEA中實體類(POJO)與JSON快速互轉(zhuǎn)問題
這篇文章主要介紹了IDEA中實體類(POJO)與JSON快速互轉(zhuǎn),本文通過圖文實例代碼相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08java 多線程Thread與runnable的區(qū)別
這篇文章主要介紹了java 多線程Thread與runnable的區(qū)別的相關(guān)資料,java線程有兩種方法繼承thread類與實現(xiàn)runnable接口,下面就提供實例幫助大家理解,需要的朋友可以參考下2017-08-08將Java程序與數(shù)據(jù)庫進(jìn)行連接的操作方法
這篇文章主要介紹了將Java程序與數(shù)據(jù)庫進(jìn)行連接的操作方法,是Java入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-10-10