日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

mybatis 动态传入表名 注解_Mybatis动态sql的动态表名问题

發布時間:2023/12/19 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybatis 动态传入表名 注解_Mybatis动态sql的动态表名问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

update #{tableName} set iobsolete= 1,update_date =#{date} where reg_id in#{id}

一開始這樣寫的sql,sql語句的表名會有引號,導致sql報錯,需要想辦法去掉#{tableName}的引號。查了半天發現mybatis的update標簽有個屬性:statementType。

statementType的值設為STATEMENT可以滿足我們的需求,把表名的引號去掉,但是同時也去掉了參數的引號,這樣還是有問題。對Statement和PrepareStatement的理解具體可以參閱:http://wenku.baidu.com/view/ccb9da020740be1e650e9abc.html

把statementType的值設為STATEMENT后,我們需要注意sql里的參數如 #{tableName}、#{date} 都需要改為${},不然無法把參數拼接上去。

做完這些工作之后,我們需要注意的是,我們傳的參數值(除去表名、表字段)的引號也被去掉了,我們需要在給參數加上引號,此時我們可以使用轉義符:' 是單引號,

值得注意的是:

(1)轉義序列字符之間不能有空格;

(2) 轉義序列必須以”;”結束;

(3) 單獨出現的”&”不會被認為是轉義的開始;

(4) 區分大小寫。

最終一個正確的表名動態的sql為:

update ${tableName} set iobsolete= 1,update_date = '${date}' where reg_id in

'${id}'

總結

以上是生活随笔為你收集整理的mybatis 动态传入表名 注解_Mybatis动态sql的动态表名问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。