久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:4日期:2022-08-23 16:49:04

1、#和$兩者含義不同

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

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

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

$name$ = 張三#name# =’張三’

因此使用$就會報錯,若要使用$的話,需要修改為’$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,’張三’);//自動進(jìn)行java類型和jdbc類型轉(zhuǎn)換

3、#和$使用場景不同

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

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

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

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

例如:

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

特別說明,$只是字符串拼接,所以要特別小心sql注入問題。

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 成人免费福利 | 香蕉成人啪国产精品视频综合网 | 久草久草久草 | 国产91亚洲精品久久久 | 中文字幕一区二区三区不卡 | 久久机热 | 欧美精品日韩 | 毛片网站免费在线观看 | 亚洲高清在线观看 | 精品国产区 | 久久不卡日韩美女 | 一区二区亚洲视频 | 欧美一区二区三区xxxx监狱 | 特黄特色大片免费视频观看 | 日韩中文字幕一区二区 | 免费av在线播放 | 一区二区三区欧美在线 | 亚洲福利av | 精品国产乱码久久久久久久软件 | 99精彩视频 | 91精品国产乱码久久久久久久久 | 久久久久综合狠狠综合日本高清 | 99在线视频精品 | 国产一级纯肉体一级毛片 | 激情欧美一区二区三区中文字幕 | 欧美日韩一区二区在线 | 亚洲精品久久久狠狠狠爱 | 日韩午夜电影在线观看 | 免费看国产一级片 | 国外成人在线视频网站 | 黄片毛片一级 | 成人激情视频免费观看 | 四虎影院在线 | 国产欧美日韩精品一区二区三区 | 中文一区二区 | 在线久草| 久久精品国产免费 | 亚洲天堂电影网 | 国产精品乱码久久 | 成人免费小视频 | 四虎永久免费影视 |