91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java ibatis #及$的區別和用法是什么

發布時間:2020-10-30 15:35:58 來源:億速云 閱讀:143 作者:Leah 欄目:開發技術

java ibatis #及$的區別和用法是什么?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

1、#和$兩者含義不同

#:會進行預編譯,而且進行類型匹配;

$:不進行數據類型匹配。

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

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

因此使用$就會報錯,若要使用$的話,需要修改為'$name$';

2、兩者的實現方式不同

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)# 作用相當于變量替換

select * from users where name = #name#

等效于

prepareStement=stmt.createPrepareStement("select * from users where name = ?")
prepareStement.setString(1,'張三');//自動進行java類型和jdbc類型轉換

3、#和$使用場景不同

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

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

3.2)$只是簡單的字符拼接而已,對于非變量部分,那只能使用$,實際上,在很多場合,$也是有很多實際意義的

$方式一般用于傳入數據庫對象(如傳入表名)

例如:

  • select * from $tableName$ 對于不同的表執行統一的查詢
  • update $tableName$ set name = #name# 每個實體一張表,改變不用實體的狀態特別說明,$只是字符串拼接,所以要特別小心sql注入問題。

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

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

陕西省| 东源县| 敦煌市| 马尔康县| 辽宁省| 西乌珠穆沁旗| 茌平县| 青神县| 大关县| 盐边县| 化州市| 寿宁县| 贵南县| 云龙县| 肇东市| 新和县| 团风县| 泽州县| 雷州市| 彩票| 宜宾市| 吉林省| 米易县| 故城县| 武汉市| 崇左市| 合水县| 历史| 石嘴山市| 房山区| 朝阳区| 河东区| 乌拉特前旗| 余江县| 青铜峡市| 新和县| 隆林| 灵丘县| 炎陵县| 黄平县| 邓州市|