博文發布出發點:
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()); } } }