MyBatis 封裝Map,返回不同實體的集合對象


博文發布出發點:

  1.現在有一個需求,就是從100個表中獲得任意表中的數據,按照正常的思維模式和處理方式,

    我們首先會創建100個實體類(累死!),然后通過resultType一一對應實體類,這種方式簡直... 

  2.我們不通過創建實體類,來獲得一個表中的所有數據,或者部分數據的鍵值對形式的值,我們該怎么做?

那么我們下面將會用一種相對高效的方式來解決問題!

 

最初的想法,匯聚成了如下的代碼

List<Object> findStatisData();

<mapper namespace="cn.arebirth.mapper.IncomeMapper">
    <select id="findStatisData" resultType="java.lang.Object">
        select * from data
    </select>
</mapper>

但是這樣寫拿到的數據只有一列,這時為什么??sql語句都沒有問題?

原因是,當我們的resultType寫成一個實體類的時候,MyBatis首先會找這個實體類里面的字段,然后根據字段進行映射,

但是我們的Object對象它里面有字段嗎???

當然是沒有的,所以只能獲得一個值。

-------------------------------------------------------------------

像這種想要返回實體類的東西我們還得借助Map<String,Object>,為什么呢?

String就相當於實體類里面的具體屬性字段,而Object就是存儲值的

 

所以我們的寫法應該是這樣的

 

/*
  Warning:
    這里邊如果是要獲取多個值的話就必須寫成List<Map<String,Object>>
    如果要寫成Map<String,Object>,它只會獲取一條數據,如果你查詢的是多條數據的話,還會報異常!!
*/
List<Map<String,Object>> findStatisData(); <mapper namespace="cn.arebirth.mapper.IncomeMapper"> <select id="findStatisData" resultType="java.util.Map"> select * from data </select> </mapper>

 

這樣的話我們就可以獲得所有的字段名加值的lList集合嵌套Map的值了。

 

最終我們可以通過如下的方式,打印出所有的key(留給比較懵逼的同學看)

package cn.arebirth.test;

import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;

import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

import cn.arebirth.mapper.IncomeMapper;
import cn.arebirth.util.MyBatisUtil;

public class TestIncome {
    
    @Test
    public void test() {
        SqlSession session = MyBatisUtil.getSession();
        IncomeMapper mapper = session.getMapper(IncomeMapper.class);
        
        List<Map<String,Object>> data = mapper.findStatisData();
        for (int i = 0; i < data.size(); i++) {
            HashMap<Object, Object> map = (HashMap)data.get(i);
            Set<Object> keySet = map.keySet();
            System.out.println(keySet.toString());
        }
    }
    
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM