mybatis中数据库字段与实体类属性的对应关系

本文介绍了解决MyBatis查询User实体时,openAppKey属性为空的问题。提供了两种解决方案:一是直接修改SQL查询语句;二是通过配置resultMap进行字段映射。

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

User实体对象的属性:
private String id;
private String secretKey;
private String openAppKey;

对应数据库字段:
ID varchar(32)
SECRET_KEY varchar(255)
app_key varchar(50)

MyBatis配置文件:
<select id="getUserByOpenId" resultType="com.test.User">
    SELECT *
    FROM SYSTEM_USER
    WHERE open_id = #{openId}
</select>

问题:

查询后,User实体对象getOpenAppKey()为null。

 

解决方法:

方法1:直接修改查询语句

<select id="getUserByOpenId" resultType="com.test.User">
    SELECT ID, SECRET_KEY, app_key as open_app_key
    FROM SYSTEM_USER
    WHERE open_id = #{openId}
</select>

 

方法2:新增配置:

<resultMap id="BaseResultMap" type="com.test.User">

    <id column="ID" property="id"/>

    <result column="SECRET_KEY" property="secretKey"/>

    <result column="app_key" property="openAppKey"/>

</resultMap>

修改配置:

<select id="getUserByOpenId" resultMap="BaseResultMap">
    SELECT *
   
FROM SYSTEM_USER
    WHERE open_id = #{openId}
</select>

 

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值