亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

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

2019-11-06 06:01:52
字體:
來源:轉載
供稿:網友
輸出映射接下來說說有關Mapper.xml配置文件中查詢標簽中關于返回值類型resultType與resultMap的一些內容1.resultType使用resultType進行輸出映射,只有查詢出來的列名和pojo中的屬性名一致,該列才可以映射成功。如果查詢出來的列名和pojo中的屬性名全部不一致,沒有創建pojo對象。只要查詢出來的列名和pojo中的屬性有一個一致,就會創建pojo對象。1.1輸出簡單類型1.1.1需求用戶信息的綜合查詢列表總數,通過查詢總數和上邊用戶綜合查詢列表才可以實現分頁。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();                    //創建UserMapper代理對象          UserMapper userMapper=sqlSession.getMapper(UserMapper.class);                    //創建包裝對象,設置查詢條件          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>生成的動態代理對象中是根據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();                //創建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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕精品视频| 亚洲电影免费观看高清完整版| 国产999在线观看| 国产精品偷伦免费视频观看的| 国产91亚洲精品| 91免费国产视频| 亚洲精品www| 色系列之999| 欧美激情2020午夜免费观看| 91久久夜色精品国产网站| 亚洲级视频在线观看免费1级| 日韩电影在线观看免费| 亚洲综合中文字幕在线| 亚洲精品欧美日韩| 国产精品白丝jk喷水视频一区| 九九热在线精品视频| 亚洲码在线观看| 欧美一级片一区| 自拍亚洲一区欧美另类| 久久夜色精品亚洲噜噜国产mv| 亚洲激情自拍图| 8x拔播拔播x8国产精品| 日韩成人激情影院| 中文字幕久久亚洲| 九色成人免费视频| 欧美激情按摩在线| 亚洲成人黄色网址| 欧美理论电影在线播放| 久久久久久综合网天天| 91美女福利视频高清| 青青草精品毛片| 91高清在线免费观看| 亚洲精品电影在线观看| 国产91精品视频在线观看| 国产日韩欧美影视| 亚洲欧美制服第一页| 久久久久久尹人网香蕉| 国产亚洲精品美女| 人人爽久久涩噜噜噜网站| 欧美性猛xxx| 久久久久久国产三级电影| 国产精品久久久久77777| 精品日本高清在线播放| 亚洲综合中文字幕68页| 国产欧美精品一区二区三区-老狼| 国产精品福利网| 亚洲精品中文字幕av| 国产成人精品免高潮在线观看| 国产精品久久久久久久久免费看| 青青a在线精品免费观看| 疯狂欧美牲乱大交777| 亚洲人成免费电影| 久久久久成人网| 国产99久久精品一区二区| 国产精品精品一区二区三区午夜版| 亚洲丝袜av一区| 亚洲欧美日韩一区二区在线| 九九视频直播综合网| 精品国模在线视频| 深夜精品寂寞黄网站在线观看| 国产亚洲精品久久久优势| 一区二区欧美亚洲| www.日韩视频| 69影院欧美专区视频| 91美女高潮出水| 亚洲а∨天堂久久精品喷水| 久久视频国产精品免费视频在线| 欧美另类交人妖| 欧美精品日韩www.p站| 精品日本美女福利在线观看| 法国裸体一区二区| 91亚洲精品一区二区| 久久91亚洲人成电影网站| 久久偷看各类女兵18女厕嘘嘘| 日本成人黄色片| 国产视频丨精品|在线观看| 日韩av在线网站| 神马国产精品影院av| 青青草原一区二区| 亚洲激情视频在线播放| 国产日韩在线视频| 国产精品视频公开费视频| 91九色单男在线观看| 福利视频一区二区| 成人久久18免费网站图片| 国产欧美精品久久久| 97香蕉久久超级碰碰高清版| 久久99国产精品自在自在app| 亚洲人成电影网| 亚洲欧美国产精品va在线观看| 欧美专区国产专区| 精品视频在线播放免| 亚洲一区二区久久久久久| 91免费人成网站在线观看18| 欧美成人在线影院| 亚洲mm色国产网站| 在线观看91久久久久久| 欧美激情久久久久| 国产精品久久久久高潮| 日韩欧美aⅴ综合网站发布| 亚洲一区二区三区四区在线播放| 国产伦精品一区二区三区精品视频| 国产精品激情av电影在线观看| 成人美女免费网站视频| 色99之美女主播在线视频| 欧美在线免费观看| 亚洲欧美日韩视频一区| 久久躁狠狠躁夜夜爽| 日韩高清免费观看| 日韩av色在线| 国产91精品青草社区| 亚洲在线一区二区| 国产日韩欧美中文在线播放| 亚洲奶大毛多的老太婆| 欧美激情极品视频| 精品偷拍各种wc美女嘘嘘| 亚洲电影第1页| 欧美日韩视频免费播放| 久久久天堂国产精品女人| 欧美黑人一区二区三区| 最近更新的2019中文字幕| 精品久久久久久久久久久久久| 亚洲中国色老太| 亚洲黄色www网站| 日韩欧美在线看| 亚洲第一区在线观看| 成人午夜在线影院| 久久久精品2019中文字幕神马| 精品亚洲一区二区三区在线播放| 国产一区二区日韩精品欧美精品| 人九九综合九九宗合| 这里只有精品视频| 日韩资源在线观看| 最近2019中文字幕在线高清| 国产欧美精品va在线观看| 亚洲第五色综合网| 91免费高清视频| 亚洲一区二区福利| 欧美性猛交99久久久久99按摩| 欧美大片欧美激情性色a∨久久| 91产国在线观看动作片喷水| 亚洲天堂av综合网| 亚洲国产日韩欧美在线动漫| 欧美自拍大量在线观看| 欧美日韩高清在线观看| 国产成人精品av在线| 欧美日韩国产综合视频在线观看中文| 亚洲一区美女视频在线观看免费| 欧美日韩成人在线观看| 日本电影亚洲天堂| 神马久久桃色视频| 日韩av色综合| 久久精品亚洲精品| 91九色视频导航| 日韩精品视频在线观看网址| 国产亚洲美女久久| 欧美一区二粉嫩精品国产一线天| 亚洲欧美国产精品专区久久| 亚洲女人初尝黑人巨大| zzjj国产精品一区二区| 成人淫片在线看| 中文字幕精品久久| 日本a级片电影一区二区| 91网站免费观看|