av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

簡單了解java ibatis #及$的區別和用法

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

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 精品欧美一区免费观看α√ | 精品久久久久久亚洲国产800 | 电影91久久久 | 国产精品一区在线 | 狠狠操狠狠色 | 国产影音先锋 | 精品伦精品一区二区三区视频 | 精品日韩一区 | 在线色网| 日本三级电影免费 | 国产高清免费在线 | 国户精品久久久久久久久久久不卡 | 欧美不卡视频 | 欧美一区二区三区在线观看 | 福利网站在线观看 | 伊人久久精品一区二区三区 | 一级黄色绿像片 | 1区2区视频 | 欧美日韩综合一区 | 蜜桃臀av一区二区三区 | 特黄毛片视频 | 国产精品欧美大片 | 日本亚洲一区 | 精品三级在线观看 | 3p视频在线观看 | 黄网站涩免费蜜桃网站 | 日韩欧美在线精品 | 日韩免费福利视频 | 一区二区三区网站 | 97精品久久 | 亚洲综合无码一区二区 | 欧美日韩在线一区二区 | 亚洲欧洲国产视频 | 欧美天堂一区 | 久久999| 成人久久久久久久久 | 欧美日韩一 | 久久一区精品 | 精品九九九 | 日韩国产中文字幕 | 青草青草久热精品视频在线观看 |