MyBatis配置文件resultMap可省略的情况

  1. MyBatis的映射配置文件中的<resultMap>标签或该标签中的子标签<id>、<result>可省略。

    一、bean中的属性名与数据库的字段名不同,无法省略<resultMap>。


  2. <pre name="code" class="java">public class User {  
  3.     private int idx;  
  4.     private String usernamex;  
  5.     private String passwordx;  
  6.     /*getter和setter方法省略*/  
  7. }</pre><br>  
  8. <pre></pre>  
  9. <p></p>  
  10. <pre></pre>  
  11. 配置文件  
  12. <p></p>  
  13. <p><span style="font-size:18px"></span></p>  
  14. <pre name="code" class="java">    <!--column为数据库列名,property为bean的属性名,两者名字不相同的情况不能省略-->  
  15.     <resultMap id="userMap" type="com.yykj.beans.User">  
  16.         <id column="id" property="idx" jdbcType="INTEGER"/>  
  17.         <result column="username" property="usernamex" jdbcType="VARCHAR"/>  
  18.         <result column="password" property="passwordx" jdbcType="VARCHAR"/>  
  19.     </resultMap></pre>在这种情况下,<resultMap>下的每一个子标签代表了一个映射关系,不能省略。  
  20. <p></p>  
  21. <p><span style="font-size:18px">若<resultMap>下的子标签都省略了,那么会生成一个null对象,并加入映射结果的List对象中,如果有任何一个子标签存在,则会生成一个bean对象,只有未省略的那一项标签的属性值不为null,其它都为null。</span></p>  
  22. <p><span style="font-size:18px">二、bean中的属性名和数据库的字段名,可以省略<resultMap>下的子标签。</span></p>  
  23. <p><span style="font-size:18px">User.java</span></p>  
  24. <pre name="code" class="java">public class User {  
  25.     private int id;  
  26.     private String username;  
  27.     private String password;  
  28.     /*getter和setter方法省略*/  
  29. }</pre>配置文件<pre name="code" class="java">    <resultMap id="userMap" type="com.yykj.beans.User">  
  30.         <!--以下标签可以省略任意项,Mybatis会根据java反射机制自动识别。-->  
  31. <!--        <id column="id" property="id" jdbcType="INTEGER"/>  
  32.         <result column="username" property="username" jdbcType="VARCHAR"/>  
  33.         <result column="password" property="password" jdbcType="VARCHAR"/>-->  
  34.     </resultMap></pre><resultMap>下的标签可以省略任意项,甚至可以全部省略。  
  35. <p></p>  
  36. <p><span style="font-size:18px">三、<span style="font-size:18px">bean中的属性名和数据库的字段名,可以不用<resultMap>,使用resultType替代。</span></span></p>  
  37. <p><span style="font-size:18px"></span></p>  
  38. <pre code_snippet_id="2394545" snippet_file_name="blog_20170515_5_8556038" name="code" class="java">    <select id="selectAllUser" resultType="com.yykj.beans.User">  
  39.         SELECT * FROM user  
  40.     </select></pre><span style="color:#ff0000">MyBatis框架强大的功能都得益于Java的反射机制。</span><br>  
  41. <br>  
  42. <br>  
  43. <br>  
  44. <p></p>  
  45.      
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值