av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

在MyBatis中使用 # 和 $ 書寫占位符的區別說明

瀏覽:2日期:2023-10-22 11:33:01

#將傳入的數據都當成一個字符串,會對傳入的數據自動加上引號;

$將傳入的數據直接顯示生成在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中使用 # 和 $ 書寫占位符的區別說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 人人天天操 | 日本精品一区二区三区在线观看视频 | 天天天操| www国产成人免费观看视频,深夜成人网 | 在线国产小视频 | 亚洲视频在线观看一区二区三区 | 色眯眯视频在线观看 | 欧美电影免费观看 | 最近中文字幕第一页 | 欧美日韩国产中文 | a精品视频 | 国产精品地址 | 91欧美激情一区二区三区成人 | 国产精品视频久久 | 亚洲男人网 | 91九色视频 | 波多野结衣一区二区三区在线观看 | 综合二区 | 久久久久国产一区二区三区四区 | 久久在线 | 免费一级黄色录像 | 国产性色视频 | 久久欧美高清二区三区 | 天天操人人干 | 草久久| 男人的天堂在线视频 | 综合中文字幕 | 久草福利| 九九热在线免费观看 | 最新中文字幕第一页视频 | 日韩欧美在线免费观看 | 国产激情在线 | 久久国产精品一区二区三区 | 亚洲一区二区三区在线播放 | h视频在线免费 | 久久久久久九九九九 | 粉嫩国产精品一区二区在线观看 | 国产精品视频一区二区三区, | 精品国产视频 | 成人免费观看男女羞羞视频 | 一区二区三区在线免费观看 |