亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2020年12月02日 11:37:24   作者:零三一  
這篇文章主要介紹了Mybatis 動態(tài)表名+Map參數(shù)傳遞+批量操作詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

需求:

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

1,查詢操作:

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

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

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

2,批量插入操作:

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

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

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

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

補(bǔ)充知識:mybatis動態(tài)傳入表名并返回map,返回空間點(diǎn)的坐標(biāo)

mybatis學(xué)習(xí)中

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

xml文件

<select id="selectLocationByPrimaryKey" 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,因?yàn)橛闷渌脩暨B接的數(shù)據(jù)庫 所以查詢其他用戶下的表的時候必須用用戶名加表名。當(dāng)然前提你這個用戶有查詢其他用戶表的權(quán)限。params類型是HashMap。xml文件中取值時候必須要跟此地方綁定的key值一直,不然取到為null.此處key為xml文件的時候查詢列的別名。

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

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

相關(guān)文章

  • IDEA EasyCode 一鍵幫你生成所需代碼

    IDEA EasyCode 一鍵幫你生成所需代碼

    這篇文章主要介紹了IDEA EasyCode 一鍵幫你生成所需代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 復(fù)雜JSON字符串轉(zhuǎn)換為Java嵌套對象的實(shí)現(xiàn)

    復(fù)雜JSON字符串轉(zhuǎn)換為Java嵌套對象的實(shí)現(xiàn)

    這篇文章主要介紹了復(fù)雜JSON字符串轉(zhuǎn)換為Java嵌套對象的實(shí)現(xiàn),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Java嵌入式開發(fā)的優(yōu)勢及有點(diǎn)總結(jié)

    Java嵌入式開發(fā)的優(yōu)勢及有點(diǎn)總結(jié)

    在本篇內(nèi)容里小編給大家整理了關(guān)于Java嵌入式開發(fā)的優(yōu)勢及相關(guān)知識點(diǎn)內(nèi)容,有興趣的朋友們學(xué)習(xí)下。
    2022-11-11
  • Java中的動態(tài)綁定機(jī)制

    Java中的動態(tài)綁定機(jī)制

    這篇文章主要介紹了Java中的動態(tài)綁定機(jī)制,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 詳解Java編程中面向字符的輸出流

    詳解Java編程中面向字符的輸出流

    這篇文章主要介紹了Java編程中面向字符的輸出流,是Java入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-10-10
  • sftp和ftp 根據(jù)配置遠(yuǎn)程服務(wù)器地址下載文件到當(dāng)前服務(wù)

    sftp和ftp 根據(jù)配置遠(yuǎn)程服務(wù)器地址下載文件到當(dāng)前服務(wù)

    這篇文章主要介紹了sftp和ftp 根據(jù)配置遠(yuǎn)程服務(wù)器地址下載文件到當(dāng)前服務(wù)的相關(guān)資料本文給大家介紹的非常詳細(xì),具有參考借鑒價值,需要的朋友可以參考下
    2016-10-10
  • java教程之java注解annotation使用方法

    java教程之java注解annotation使用方法

    這篇文章主要介紹了java注解annotation使用方法,注解可以定義到方法上,類上,一個注解相當(dāng)與一個類,就相當(dāng)于實(shí)例了一個對象,加上了注解,就相當(dāng)于加了一個標(biāo)志
    2014-01-01
  • Java線程的6種狀態(tài)及切換教程

    Java線程的6種狀態(tài)及切換教程

    這篇文章主要給大家介紹了關(guān)于Java線程的6種狀態(tài)及切換教程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 使用java模擬簡單的tomcat的方法詳解

    使用java模擬簡單的tomcat的方法詳解

    這篇文章主要為大家詳細(xì)介紹了java模擬簡單的tomcat的方法,使用數(shù)據(jù)庫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Java中File類方法詳解以及實(shí)踐

    Java中File類方法詳解以及實(shí)踐

    Java File類的功能非常強(qiáng)大,利用java基本上可以對文件進(jìn)行所有操作,下面這篇文章主要給大家介紹了關(guān)于Java中File類方法以及實(shí)踐的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04

最新評論