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

本文探讨了在MyBatis映射配置文件中,当bean属性名与数据库字段名相同时,<resultMap>、<id>和<result>标签可以省略的情况。但若两者不一致,<resultMap>及其子标签则必不可少。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

User.java

public class User {
    private int idx;
    private String usernamex;
    private String passwordx;
    /*getter和setter方法省略*/
}



配置文件

    <!--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>
在这种情况下,<resultMap>下的每一个子标签代表了一个映射关系,不能省略。

若<resultMap>下的子标签都省略了,那么会生成一个null对象,并加入映射结果的List对象中,如果有任何一个子标签存在,则会生成一个bean对象,只有未省略的那一项标签的属性值不为null,其它都为null。

二、bean中的属性名和数据库的字段名,可以省略<resultMap>下的子标签。

User.java

public class User {
    private int id;
    private String username;
    private String password;
    /*getter和setter方法省略*/
}
配置文件
    <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>
<resultMap>下的标签可以省略任意项,甚至可以全部省略。

三、bean中的属性名和数据库的字段名,可以不用<resultMap>,使用resultType替代。

    <select id="selectAllUser" resultType="com.yykj.beans.User">
        SELECT * FROM user
    </select>
MyBatis框架强大的功能都得益于Java的反射机制。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值