亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

簡(jiǎn)單了解java ibatis #及$的區(qū)別和用法

 更新時(shí)間:2020年09月27日 16:18:24   作者:愛(ài)笑的berg  
這篇文章主要介紹了簡(jiǎn)單了解java ibatis #及$的區(qū)別和用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

1、#和$兩者含義不同

#:會(huì)進(jìn)行預(yù)編譯,而且進(jìn)行類型匹配;

$:不進(jìn)行數(shù)據(jù)類型匹配。

示例:變量name的類型是string, 值是"張三"

$name$ = 張三
#name# ='張三'

因此使用$就會(huì)報(bào)錯(cuò),若要使用$的話,需要修改為'$name$';

2、兩者的實(shí)現(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,'張三');//自動(dòng)進(jìn)行java類型和jdbc類型轉(zhuǎn)換

3、#和$使用場(chǎng)景不同

3.1)變量的傳遞,必須使用#。可以防止sql注入,#是用prepareStement,提示效率

#方式一般用于傳入添加/修改的值或查詢/刪除的where條件

3.2)$只是簡(jiǎn)單的字符拼接而已,對(duì)于非變量部分,那只能使用$,實(shí)際上,在很多場(chǎng)合,$也是有很多實(shí)際意義的

$方式一般用于傳入數(shù)據(jù)庫(kù)對(duì)象(如傳入表名)

例如:

  • select * from $tableName$ 對(duì)于不同的表執(zhí)行統(tǒng)一的查詢
  • update $tableName$ set name = #name# 每個(gè)實(shí)體一張表,改變不用實(shí)體的狀態(tài)

特別說(shuō)明,$只是字符串拼接,所以要特別小心sql注入問(wèn)題。

3.3)能同時(shí)使用#和$的時(shí)候,最好用#

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 從?JVM?中深入探究?Synchronized作用及原理

    從?JVM?中深入探究?Synchronized作用及原理

    這篇文章主要為大家介紹了從?JVM?中深入探究?Synchronized作用及原理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • Spring?Security圖形驗(yàn)證碼的實(shí)現(xiàn)代碼

    Spring?Security圖形驗(yàn)證碼的實(shí)現(xiàn)代碼

    本文介紹了如何在SpringSecurity自定義認(rèn)證中添加圖形驗(yàn)證碼,首先需要在maven中添加相關(guān)依賴并創(chuàng)建驗(yàn)證碼對(duì)象,然后通過(guò)Spring的HttpSessionSessionStrategy對(duì)象將驗(yàn)證碼存儲(chǔ)到Session中,感興趣的朋友跟隨小編一起看看吧
    2024-10-10
  • java中的正則操作方法總結(jié)

    java中的正則操作方法總結(jié)

    關(guān)于正則表達(dá)式的使用,更多的是自己的經(jīng)驗(yàn),有興趣可以參閱相關(guān)書(shū)籍。這里主要寫一下java中的正則操作方法
    2013-10-10
  • springboot+thymeleaf打包成jar后找不到靜態(tài)資源的坑及解決

    springboot+thymeleaf打包成jar后找不到靜態(tài)資源的坑及解決

    這篇文章主要介紹了springboot+thymeleaf打包成jar后找不到靜態(tài)資源的坑及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • SpringBoot使用Sa-Token實(shí)現(xiàn)路徑攔截和特定接口放行

    SpringBoot使用Sa-Token實(shí)現(xiàn)路徑攔截和特定接口放行

    這篇文章主要介紹了SpringBoot使用Sa-Token實(shí)現(xiàn)路徑攔截和特定接口放行,文中通過(guò)代碼示例講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-06-06
  • IDEA中實(shí)體類(POJO)與JSON快速互轉(zhuǎn)問(wèn)題

    IDEA中實(shí)體類(POJO)與JSON快速互轉(zhuǎn)問(wèn)題

    這篇文章主要介紹了IDEA中實(shí)體類(POJO)與JSON快速互轉(zhuǎn),本文通過(guò)圖文實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • JAVA時(shí)間存儲(chǔ)類Period和Duration使用詳解

    JAVA時(shí)間存儲(chǔ)類Period和Duration使用詳解

    這篇文章主要為大家介紹了JAVA時(shí)間存儲(chǔ)類Period和Duration使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • java 多線程Thread與runnable的區(qū)別

    java 多線程Thread與runnable的區(qū)別

    這篇文章主要介紹了java 多線程Thread與runnable的區(qū)別的相關(guān)資料,java線程有兩種方法繼承thread類與實(shí)現(xiàn)runnable接口,下面就提供實(shí)例幫助大家理解,需要的朋友可以參考下
    2017-08-08
  • 淺析NIO系列之TCP

    淺析NIO系列之TCP

    NIO即同步非阻塞式IO,它和傳統(tǒng)的BIO比較最大的區(qū)別在于在執(zhí)行accept、connect、read、write操作時(shí)是非阻塞的。很有利于實(shí)現(xiàn)用少量線程來(lái)處理多個(gè)客戶端請(qǐng)求,可以隨時(shí)讓線程切換所處理的客戶端,從而可以實(shí)現(xiàn)高并發(fā)服務(wù)器的開(kāi)發(fā)
    2021-06-06
  • 將Java程序與數(shù)據(jù)庫(kù)進(jìn)行連接的操作方法

    將Java程序與數(shù)據(jù)庫(kù)進(jìn)行連接的操作方法

    這篇文章主要介紹了將Java程序與數(shù)據(jù)庫(kù)進(jìn)行連接的操作方法,是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-10-10

最新評(píng)論