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