1. 程式人生 > 程式設計 >簡單瞭解java ibatis #及$的區別和用法

簡單瞭解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)能同時使用#和$的時候,最好用#

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。