国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

【Mybatis框架】輸出映射-resultType與resultMap

2019-11-06 06:01:52
字體:
來源:轉載
供稿:網友
輸出映射接下來說說有關Mapper.xml配置文件中查詢標簽中關于返回值類型resultType與resultMap的一些內容1.resultType使用resultType進行輸出映射,只有查詢出來的列名和pojo中的屬性名一致,該列才可以映射成功。如果查詢出來的列名和pojo中的屬性名全部不一致,沒有創(chuàng)建pojo對象。只要查詢出來的列名和pojo中的屬性有一個一致,就會創(chuàng)建pojo對象。1.1輸出簡單類型1.1.1需求用戶信息的綜合查詢列表總數,通過查詢總數和上邊用戶綜合查詢列表才可以實現(xiàn)分頁。1.1.2mapper.xml[html] view plain copy<mapper namespace="cn.edu.hpu.mybatis.mapper.UserMapper">            <!-- 用戶信息綜合查詢       #{UserCustom.sex}取出包裝對象中性別值      ${UserCustom.username}取得pojo包裝對象中用戶名稱      -->      <select id="findUserList" parameterType="cn.edu.hpu.mybatis.PO.UserQueryVo"                                   resultType="cn.edu.hpu.mybatis.PO.UserCustom">          select * from user where user.sex=#{userCustom.sex} and user.username like '%${userCustom.username}%'      </select>            <!-- 用戶信息綜合查詢總數 -->      <select id="findUserCount" parameterType="cn.edu.hpu.mybatis.PO.UserQueryVo" resultType="int">          select count(*) from user where user.sex=#{userCustom.sex} and user.username like '%${userCustom.username}%'      </select>      ......  </mapper>  1.1.3mapper.java[java] view plain copy//用戶管理的Dao接口  public interface UserMapper {            //用戶信息綜合查詢      public List<UserCustom> findUserList(UserQueryVo userQueryVo) throws Exception;            //用戶信息綜合查詢總數      public int findUserCount(UserQueryVo userQueryVo) throws Exception;      ......  }  1.1.4測試代碼[java] view plain copy//用戶信息綜合查詢總數      @Test      public void testFindUserCount() throws Exception{                    Sqlsession sqlSession=sqlSessionFactory.openSession();                    //創(chuàng)建UserMapper代理對象          UserMapper userMapper=sqlSession.getMapper(UserMapper.class);                    //創(chuàng)建包裝對象,設置查詢條件          UserQueryVo userQueryVo=new UserQueryVo();          UserCustom userCustom=new UserCustom();          userCustom.setSex("男");          userCustom.setUsername("張三");          userQueryVo.setUserCustom(userCustom);                    //調用userMapper的方法          int count=userMapper.findUserCount(userQueryVo);                    System.out.PRintln("總數為:"+count);      }  測試結果:總數為:2輸出日志:[plain] view plain copyDEBUG [main] - Opening JDBC Connection  DEBUG [main] - Created connection 7832149.  DEBUG [main] - Setting autocommit to false on JDBC Connection [com.MySQL.jdbc.Connection@778255]  DEBUG [main] - ==>  Preparing: select count(*) from user where user.sex=? and user.username like '%張三%'   DEBUG [main] - ==> Parameters: 男(String)  DEBUG [main] - <==      Total: 1  1.1.5小結查詢出來的結果集只有一行且一列,可以使用簡單類型進行輸出映射。(輸出簡單類型的要求)1.2輸出pojo對象和pojo列表不管是輸出的pojo單個對象還是一個列表(list中包括pojo),在mapper.xml中resultType指定的類型是一樣的。在mapper.java指定的方法返回值類型不一樣:(1)輸出單個pojo對象,方法返回值是單個對象類型 (2)輸出pojo對象list,方法返回值是List<Pojo>生成的動態(tài)代理對象中是根據mapper方法的返回值類型確定是調用selectOne(返回單個對象調用)還是selectList (返回集合對象調用 ).(3)輸出hashmap輸出pojo對象可以改用hashmap輸出類型,將輸出的字段名稱作為map的key,value為字段值。如果是集合,那就是list里面套了HashMap。2.resultMapmybatis中使用resultMap完成高級輸出結果映射。2.1resultMap使用方法如果查詢出來的列名和pojo的屬性名不一致,通過定義一個resultMap對列名和pojo屬性名之間作一個映射關系。下面來進行實驗,實驗需求2.2將下邊的sql使用User完成映射SELECT id id_,username username_ FROM USER WHERE id=#{value}User類中屬性名和上邊查詢列名不一致。resultMap使用方法:(一下屬性均定義在Mapper.xml映射文件中)(1)定義resultMap[html] view plain copy<!-- 定義resultType  將select id id_,username _username from user和User類中的屬性做一個映射關系        type:resultMap最終所映射的Java對象類型,可以使用別名  id:對resultMap的唯一標識   -->  <resultMap type="user" id="userResultMap">      <!-- id表示查詢結果集中唯一標識       column:查詢出的列名      property:type所指定的POJO中的屬性名      最終reslutMap對column和property做一個映射關系(對應關系)      -->      <id column="_id" property="id"/>      <!-- 對普通列的映射定義 -->      <result column="_username" property="username"/>  </resultMap>  (2)使用resultMap作為statement的輸出映射類型[html] view plain copy<!-- 使用resultMap進行輸出映射       resultMap:指定定義的resultMap的id,如果這個resultMap在其它的mapper文件,前面需要加namespace      -->  <select id="findUserByResultMap" parameterType="int" resultMap="userResultMap">      select id _id,username _username from user where id=#{value}  </select>  

(3)mapper接口類中添加相應方法

[java] view plain copy//用戶管理的Dao接口  public interface UserMapper {            public User findUserByResultMap(int id) throws Exception;      ......  }  

測試:[java] view plain copy@Test  public void testFindUserByResultMap() throws Exception{                SqlSession sqlSession=sqlSessionFactory.openSession();                //創(chuàng)建UserMapper代理對象      UserMapper userMapper=sqlSession.getMapper(UserMapper.class);                //調用userMapper的方法      User user=userMapper.findUserByResultMap(1);                System.out.println(user.getUsername());  }  測試結果:張三

輸出日志:

[plain] view plain copyEBUG [main] - Opening JDBC Connection  DEBUG [main] - Created connection 1465214.  DEBUG [main] - Setting autocommit to false on JDBC Connection [com.mysql.jdbc.Connection@165b7e]  DEBUG [main] - ==>  Preparing: select id _id,username _username from user where id=?   DEBUG [main] - ==> Parameters: 1(Integer)  DEBUG [main] - <==      Total: 1  

小結使用resultType進行輸出映射,只有查詢出來的列名和pojo中的屬性名一致,該列才可以映射成功。

如果查詢出來的列名和pojo的屬性名不一致,通過定義一個resultMap對列名和pojo屬性名之間作一個映射關系。

轉載請注明出處:http://blog.csdn.net/acmman/article/details/46509375


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 玛曲县| 琼中| 丽江市| 台北县| 全椒县| 卓尼县| 驻马店市| 柯坪县| 蒙自县| 文山县| 宜都市| 澎湖县| 巴青县| 宁夏| 沈丘县| 宁武县| 平罗县| 青川县| 泽州县| 灵武市| 曲沃县| 甘谷县| 延寿县| 安康市| 长寿区| 沾化县| 诸暨市| 综艺| 射洪县| 南昌市| 伊宁市| 台安县| 醴陵市| 方正县| 梅州市| 桐柏县| 新干县| 青州市| 舟山市| 莎车县| 威海市|