午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

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

Mybatis 動態(tài)表名+Map參數(shù)傳遞+批量操作詳解

瀏覽:142日期:2023-10-20 18:01:18

需求:

之前項目一個變動,需要對3張mysql數(shù)據(jù)庫表數(shù)據(jù)進行清洗,3張表表名不同,表結構完全相同,需要對這3張表進行相同的增、改、查動作,一開始比較緊急先對一張表進行操作,后來復制了3個一樣的 service、dao、mapper等。后來對代碼進行優(yōu)化,研究了一下動態(tài)表名的處理。

1,查詢操作:

查詢操作只需要傳入動態(tài)表名的時候,傳遞參數(shù)仍然是map

mapper.xml內(nèi),需要使用statementType='STATEMENT',采用非預編譯模式

mapper.xml內(nèi),動態(tài)表名的獲取使用 ${tableName}

Mybatis 動態(tài)表名+Map參數(shù)傳遞+批量操作詳解

2,批量插入操作:

查詢操作只需要傳入動態(tài)表名的時候,傳遞參數(shù)仍然是map

mapper.xml內(nèi),不需要使用statementType='STATEMENT',否則會在運行時報錯提示語法錯誤(具體原因不是很清楚)。

動態(tài)表名的獲取使用 ${tableName}, 而insert 的 collection 屬性名為傳入?yún)?shù)的map內(nèi)的key名,不需要任何修飾符。

list內(nèi)容使用 #{item.guid}來獲取,而不是$。

Mybatis 動態(tài)表名+Map參數(shù)傳遞+批量操作詳解

補充知識:mybatis動態(tài)傳入表名并返回map,返回空間點的坐標

mybatis學習中

動態(tài)傳入表名并返回某幾個字段map,取某個空間表的shape字段的坐標。代碼如下

xml文件

<select statementType='STATEMENT' resultType='java.util.HashMap' parameterType='java.util.Map'> select t.shape.minx as X,t.shape.miny as Y from ${sourceObj} t where OBJECTID = ${featureId} </select>

注意statementType必須,且值必須是大寫的STATEMENT,參數(shù)傳入為多個,用map。

dao文件

public void selectLocByPK(String sourceObj, Long featureId) {params.put('sourceObj', 'sde.'+sourceObj);params.put('featureId', featureId);Map map = this.getSqlSessionTemplate().selectOne('selectLocationByPrimaryKey', params);Double x = (Double)map.get('X');Double y = (Double)map.get('Y');System.out.println(x+','+y);}

注意查詢的是sde用戶下的表名是參數(shù)傳遞的sourceObj,因為用其他用戶連接的數(shù)據(jù)庫 所以查詢其他用戶下的表的時候必須用用戶名加表名。當然前提你這個用戶有查詢其他用戶表的權限。params類型是HashMap。xml文件中取值時候必須要跟此地方綁定的key值一直,不然取到為null.此處key為xml文件的時候查詢列的別名。

只是一條數(shù)據(jù),多條數(shù)據(jù)可以用selectList 方法 返回List ,xml基本不用變。

以上這篇Mybatis 動態(tài)表名+Map參數(shù)傳遞+批量操作詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

相關文章:
主站蜘蛛池模板: 婷婷香蕉 | 欧美精品免费在线观看 | 一区二区三区免费在线 | 四虎视频国产精品免费入口 | 日本久热 | 俺去啦最新网址 | 亚洲第九十九页 | 男女激情视频在线观看 | av免费福利| 91激情在线| 夫妻性生活动态图 | 久久精品久久久久久久 | 青青草原av| 亚洲黄色免费看 | 成人日韩在线 | a毛片在线免费观看 | 精品日本一区二区三区在线观看 | 亚洲午夜网站 | 午夜免费网站 | 亚洲欧美在线观看 | 欧美视频中文字幕 | 国产精品www| 欧美啪啪网站 | 国产精品亚洲视频 | 日韩高清不卡一区 | 国产最新网址 | 国产精品免费视频观看 | 一本黄色片 | 国产精品国产一区二区三区四区 | 91九色在线视频 | 四虎网站在线观看 | 欧美自拍区 | 亚洲精品综合在线 | 精品人伦一区二区 | 成人中文在线 | 免费在线一区二区 | 日本成人一区 | 成人午夜在线播放 | 99热免费在线观看 | 久久免费手机视频 | 免费久久精品 |