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

  • 2019 年 10 月 6 日
  • 筆記

博文發布出發點:

  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());          }      }    }