您好,登錄后才能下訂單哦!
#將傳入的數據都當成一個字符串,會對傳入的數據自動加上引號;
$將傳入的數據直接顯示生成在SQL中
注意:使用 $ 占位符可能會導致SQL注入攻擊,能用#的地方就不要使用 $
寫order by 子句的時候應該用 $ 而不是#
補充知識:mybatis 中生成的字段不帶引號 #{}和${}
最近在用mybatis,之前用過ibatis,總體來說差不多,不過還是遇到了不少問題,再次記錄下,
比如說用#{},和 ${}傳參的區別,
使用#傳入參數是,sql語句解析是會加上"",比如 select * from table where name = #{name} ,傳入的name為小李,那么最后打印出來的就是
select * from table where name = ‘小李',就是會當成字符串來解析,這樣相比于$的好處是比較明顯對的吧,#{}傳參能防止sql注入,如果你傳入的參數為 單引號',那么如果使用${},這種方式 那么是會報錯的,
另外一種場景是,如果你要做動態的排序,比如 order by column,這個時候務必要用${},因為如果你使用了#{},那么打印出來的將會是
select * from table order by 'name' ,這樣是沒用,
目前來看,能用#就不要用$,
以上這篇在MyBatis中使用 # 和 $ 書寫占位符的區別說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。