2020-12-21MyBatis中#{}和${}的區(qū)別

1墅茉、在MyBatis 的映射配置文件中命黔,動態(tài)傳遞參數(shù)有兩種方式:

  • #{}:占位符

  • ${} :拼接符

2、#{} 和 ${} 的區(qū)別

    • 1)#{} 為參數(shù)占位符 ?就斤,即sql 預編譯

    • 2)${} 為字符串替換悍募,即 sql 拼接

    • 1)#{}:動態(tài)解析 -> 預編譯 -> 執(zhí)行

    • 2)${}:動態(tài)解析 -> 編譯 -> 執(zhí)行

    • 1)#{} 的變量替換是在DBMS 中

    • 2)${} 的變量替換是在 DBMS 外

    • 1)變量替換后,#{}對應的變量自動加上單引號 ''

    • 2)變量替換后洋机,${} 對應的變量不會加上單引號 ''

    • 1)#{} 防止sql 注入 ->

    • 2)${} 防止sql 注入 -> 不能

3坠宴、#{} 和 ${} 的實例:假設傳入?yún)?shù)為 1

  • ①開始
    • 1)#{}select * from t_user where uid=#{uid}

    • 2)${}select * from t_user where uid= '${uid}'

  • ②然后
    • 1)#{}select * from t_user where uid= ?

    • 2)${}select * from t_user where uid= '1'

  • ③最后
    • 1)#{}select * from t_user where uid= '1'

    • 2)${}select * from t_user where uid= '1'

4、#{} 和 ${} 的大括號中的值

  • ① 單個參數(shù)的情形
    • 1)#{}:無MyBatis 默認值绷旗,可任意喜鼓,且與參數(shù)名無關
image
image
  • 2)${}

  • <1> 使用 MyBatis 默認值 value副砍,即 ${value}

image
image
  • <2> 使用自定義參數(shù)名,前提:在映射器接口方法的參數(shù)前加注解@Param("")
image
image
  • ② 多個參數(shù)的情形
    • 1)#{}

    • <1>使用MyBatis 默認值 arg0庄岖、arg1豁翎、arg2 … 或 param1、param2顿锰、param3 …

image
image
  • <2> 使用自定義參數(shù)名谨垃,前提:在映射器接口方法的參數(shù)前加注解@Param("")
image
image
  • 2)${}

  • <1> 使用MyBatis 默認值 arg0、arg1硼控、arg2 … 或 param1、param2胳赌、param3 …

image
image
  • <2> 使用自定義參數(shù)名牢撼,前提:在映射器接口方法的參數(shù)前加注解@Param("")
image
image

注:@Param("")@Param(value="")的簡寫

5、#{} 和 ${} 在使用中的技巧和建議

(1)不論是單個參數(shù)疑苫,還是多個參數(shù)熏版,一律都建議使用注解@Param("")

(2)能用 #{}的地方就用#{},不用或少用${}

(3)表名作參數(shù)時捍掺,必須用 ${}撼短。如:

select * from ${tableName}

(4)order by時,必須用 ${}挺勿。如:

select * from t_user order by ${columnName}

(5)使用 ${} 時曲横,要注意何時加或不加單引號,即 ${}'${}'


原博地址

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末不瓶,一起剝皮案震驚了整個濱河市禾嫉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蚊丐,老刑警劉巖熙参,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異麦备,居然都是意外死亡孽椰,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門凛篙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來黍匾,“玉大人,你說我怎么就攤上這事鞋诗“蚪荩” “怎么了?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵削彬,是天一觀的道長全庸。 經常有香客問我秀仲,道長,這世上最難降的妖魔是什么壶笼? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任神僵,我火速辦了婚禮,結果婚禮上覆劈,老公的妹妹穿的比我還像新娘保礼。我一直安慰自己,他們只是感情好责语,可當我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布炮障。 她就那樣靜靜地躺著,像睡著了一般坤候。 火紅的嫁衣襯著肌膚如雪胁赢。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天白筹,我揣著相機與錄音智末,去河邊找鬼。 笑死徒河,一個胖子當著我的面吹牛系馆,可吹牛的內容都是我干的。 我是一名探鬼主播顽照,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼由蘑,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了棒厘?” 一聲冷哼從身側響起纵穿,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎奢人,沒想到半個月后谓媒,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡何乎,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年句惯,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片支救。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡抢野,死狀恐怖,靈堂內的尸體忽然破棺而出各墨,到底是詐尸還是另有隱情指孤,我是刑警寧澤,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站恃轩,受9級特大地震影響结洼,放射性物質發(fā)生泄漏。R本人自食惡果不足惜叉跛,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一松忍、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧筷厘,春花似錦鸣峭、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至充石,卻和暖如春更扁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赫冬。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留溃列,地道東北人劲厌。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像听隐,于是被迫代替她去往敵國和親补鼻。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內容

  • MyBatis 中 #{} 和 ${} 的區(qū)別 1雅任、在MyBatis 的映射配置文件中风范,動態(tài)傳遞參數(shù)有兩種方式: ...
    Asonce閱讀 316評論 0 0
  • 1、在MyBatis 的映射配置文件中沪么,動態(tài)傳遞參數(shù)有兩種方式: (1)#{}占位符 (2)${}拼接符 2硼婿、#{...
    ULiii閱讀 517評論 0 0
  • mybatis 1.如何批量插入數(shù)據(jù) SQL層面 先復習一下單條/批量插入數(shù)據(jù)的sql語句怎么寫: 1. 單條插入...
    vincent519閱讀 788評論 0 0
  • 在mybatis接口mapper文件中引用傳入的參數(shù)是通過#{param}或者${param}來使用的。 1.數(shù)據(jù)...
    松江野人閱讀 383評論 0 0
  • 關鍵詞禽车,預編譯寇漫,防sql注入,動態(tài)sql 我們在使用mybatis中編寫sql語句的時候殉摔,經常會使用#或者$來取值...
    nged閱讀 2,646評論 0 1