-
MyBatis的映射配置文件中的<resultMap>标签或该标签中的子标签<id>、<result>可省略。
一、bean中的属性名与数据库的字段名不同,无法省略<resultMap>。
-
- <pre name="code" class="java">public class User {
- private int idx;
- private String usernamex;
- private String passwordx;
- /*getter和setter方法省略*/
- }</pre><br>
- <pre></pre>
- <p></p>
- <pre></pre>
- 配置文件
- <p></p>
- <p><span style="font-size:18px"></span></p>
- <pre name="code" class="java"> <!--column为数据库列名,property为bean的属性名,两者名字不相同的情况不能省略-->
- <resultMap id="userMap" type="com.yykj.beans.User">
- <id column="id" property="idx" jdbcType="INTEGER"/>
- <result column="username" property="usernamex" jdbcType="VARCHAR"/>
- <result column="password" property="passwordx" jdbcType="VARCHAR"/>
- </resultMap></pre>在这种情况下,<resultMap>下的每一个子标签代表了一个映射关系,不能省略。
- <p></p>
- <p><span style="font-size:18px">若<resultMap>下的子标签都省略了,那么会生成一个null对象,并加入映射结果的List对象中,如果有任何一个子标签存在,则会生成一个bean对象,只有未省略的那一项标签的属性值不为null,其它都为null。</span></p>
- <p><span style="font-size:18px">二、bean中的属性名和数据库的字段名,可以省略<resultMap>下的子标签。</span></p>
- <p><span style="font-size:18px">User.java</span></p>
- <pre name="code" class="java">public class User {
- private int id;
- private String username;
- private String password;
- /*getter和setter方法省略*/
- }</pre>配置文件<pre name="code" class="java"> <resultMap id="userMap" type="com.yykj.beans.User">
- <!--以下标签可以省略任意项,Mybatis会根据java反射机制自动识别。-->
- <!-- <id column="id" property="id" jdbcType="INTEGER"/>
- <result column="username" property="username" jdbcType="VARCHAR"/>
- <result column="password" property="password" jdbcType="VARCHAR"/>-->
- </resultMap></pre><resultMap>下的标签可以省略任意项,甚至可以全部省略。
- <p></p>
- <p><span style="font-size:18px">三、<span style="font-size:18px">bean中的属性名和数据库的字段名,可以不用<resultMap>,使用resultType替代。</span></span></p>
- <p><span style="font-size:18px"></span></p>
- <pre code_snippet_id="2394545" snippet_file_name="blog_20170515_5_8556038" name="code" class="java"> <select id="selectAllUser" resultType="com.yykj.beans.User">
- SELECT * FROM user
- </select></pre><span style="color:#ff0000">MyBatis框架强大的功能都得益于Java的反射机制。</span><br>
- <br>
- <br>
- <br>
- <p></p>
MyBatis配置文件resultMap可省略的情况
最新推荐文章于 2022-07-09 11:48:08 发布