MybatisPlus #{param}和${param}的用法詳解
作用
mybatis-plus接口mapper方法中的注解(如@Select)或者xml(如)傳入的參數(shù)是通過(guò)#{param}或者${param}來(lái)獲取值。
區(qū)別
1.解析方式:
#{param}:會(huì)進(jìn)行預(yù)編譯,而且進(jìn)行類(lèi)型匹配,最后進(jìn)行變量替換,括號(hào)中可以添加映射類(lèi)型如
#{param,javaType=int,jdbcType=NUMERIC}
${param}:只實(shí)現(xiàn)字符串拼接,并不進(jìn)行數(shù)據(jù)類(lèi)型匹配
${param}表達(dá)式主要用戶獲取配置文件數(shù)據(jù),DAO接口中的參數(shù)信息,當(dāng) $ 出現(xiàn)在映射文件的 SQl 語(yǔ)句中時(shí)創(chuàng)建的不是預(yù)編譯的 SQL ,而是字符串的拼接有可能會(huì)導(dǎo)致 SQL 注入的問(wèn)題,所以一般使用 $ 接收 DAO 參數(shù)時(shí),這些參數(shù)一般是字段名,表名等.例如 order by {column}
${} 獲取 DAO 參數(shù)數(shù)據(jù)時(shí),參數(shù)必須使用 @param 注解進(jìn)行修飾
#{} 獲取 DAO 參數(shù)數(shù)據(jù)時(shí),假如參數(shù)個(gè)數(shù)多于一個(gè),可有選擇的使用@param
2.使用
#{param}:變量值的傳遞,必須使用#,使用#{param}就等于使用了PrepareStatement這種占位符的形式,提高效率??梢苑乐箂ql注入等等問(wèn)題。
#{param}方式一般用于傳入where條件參數(shù)值
@Select( "<script>" + "select * from student where id= #{param,javaType=int,jdbcType=NUMERIC}"+ "</script> ")
${param}:$只是只是簡(jiǎn)單的字符串拼接,要特別小心sql注入問(wèn)題,對(duì)應(yīng)非變量部分,只能用$。$方式一般用于傳入數(shù)據(jù)庫(kù)對(duì)象,比如這種group by 字段 ,order by 字段,表名,字段名等沒(méi)法使用占位符的就需要使用${param}
<select id="getStatistics" resultType="map"> select count(*) from t_statistic group by ${param} </select>
到此這篇關(guān)于MybatisPlus #{param}和${param}的用法詳解的文章就介紹到這了,更多相關(guān)MybatisPlus #{param}和${param}內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Springboot GET和POST請(qǐng)求參數(shù)獲取方式小結(jié)
Spring Boot GET和POST請(qǐng)求參數(shù)獲取是開(kāi)發(fā)人員經(jīng)常需要解決的問(wèn)題,本文主要介紹了Springboot GET和POST請(qǐng)求參數(shù)獲取方式小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09詳解SpringBoot如何自定義一個(gè)Starter
小伙伴們?cè)?jīng)可能都經(jīng)歷過(guò)整天寫(xiě)著CURD的業(yè)務(wù),都沒(méi)寫(xiě)過(guò)一些組件相關(guān)的東西,這篇文章記錄一下SpringBoot如何自定義一個(gè)Starter。原理和理論就不用多說(shuō)了,可以在網(wǎng)上找到很多關(guān)于該方面的資料,這里主要分享如何自定義2022-11-11mybatisplus?isNotNull不生效問(wèn)題及解決
這篇文章主要介紹了mybatisplus?isNotNull不生效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06Java synchronized線程交替運(yùn)行實(shí)現(xiàn)過(guò)程詳解
這篇文章主要介紹了Java synchronized線程交替運(yùn)行實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11SSM框架實(shí)現(xiàn)分頁(yè)和搜索分頁(yè)的示例代碼
本篇文章主要介紹了SSM框架實(shí)現(xiàn)分頁(yè)和搜索分頁(yè)的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03Mybatis的@select和@SelectProvider注解方式動(dòng)態(tài)SQL語(yǔ)句解讀
這篇文章主要介紹了Mybatis的@select和@SelectProvider注解方式動(dòng)態(tài)SQL語(yǔ)句,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12mybatis批量添加,批量更新之前如何判斷是否已經(jīng)存在
這篇文章主要介紹了mybatis批量添加,批量更新之前如何判斷是否已經(jīng)存在,具有很好的參考價(jià)值,希望對(duì)的有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08Java位運(yùn)算和邏輯運(yùn)算的區(qū)別實(shí)例
Java位運(yùn)算和邏輯運(yùn)算的區(qū)別實(shí)例,請(qǐng)參考下面代碼,希望對(duì)你有所幫助2013-02-02