使用myBatis时要注意对象属性与表字段要对应

在使用myBatis进行ORM操作时,遇到查询结果中某字段有值但无法映射到对象属性的问题。通过分析发现,原因是model属性与数据库字段名大小写不一致导致自动映射失败。结论是,在使用myBatis做ORM时,model中的属性名称需与数据库字段保持一致。

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

这几天与一个小网站系统,发现用户在线修改密码时失败。然后debug进去,发现从数据库中查询出来的密码是null,而用工具查表其实密码是有值的。然后进一步查找user.xml文件,发现在表字段中定义的是:


UserPassword varchar(100),#密码


User.java中的密码是这样的:

/**
* 登录密码
*/
private String pwd;



当查询返回结果是带个对象时,myBatis会有一个resultType=user,这个时候他会自动去映射到对象的属性,这个时候即便UserPassword有值,但是还是无法映射到pwd当中的,所以造成了前面描述的问题。

[b]结论:以后如果用myBatis做orm的话,model里面的属性要与表字段一致(大小写可以不一致)[/b]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值