Mybatis 实体类属性名和表中字段名不一致怎么处理

一. 前言

最近耀哥有学生出去面试,被问到 "Mybatis实体类的属性名和表中的字段名不一致该怎么处理?",这其实是一个很经典的面试题,接下来耀哥就为大家详细解析一下这道面试题。

二. 分析

2.1 实体类和字段名不一致所带来的后果

为了讲清楚这个问题,我们先来设计下面这样一个案例。

表的设计如下图所示:

实体类如下图所示:

mapper.xml文件如下所示:

根据主键查询TbAccount对象的方法,我们发现【只有数据库中的字段和实体类的属性名字对得上的字段,才能被查出来!

那么以上的这个问题该怎么解决呢?耀哥给大家提出了如下两种解决方案。

2.2 解决方案一:将resultType替换为resultMap

我们需要先在mapper.xml文件中创建resultMap。

然后在mapper.xml文件的select方法节点中,把resultType替换为resultMap。

再一次根据主键查询TbAccount对象的方法,我们此时会发现,即使【数据库的列名和实体类的属性名对不上的字段,也能查出来了

2.3 解决方案二:配置下划线和驼峰的映射关系

第二种解决方案,首先要在mybatis核心配置文件中添加下划线和驼峰的映射配置。

然后把mapper.xml文件中select查询节点中的resultMap再恢复成resultType。

再一次根据主键查询TbAccount对象的方法,我们会发现【数据库的列名和实体类的属性名对不上的字段,此时依然能查出来

三. 结语

以前也经常有学生问耀哥**,[既然实体类的属性名和数据库的列名对不上会有问题,那我们在创建实体类的时候,让实体类的属性名跟数据库的字段名保持一致不就解决问题了吗?]**

其实这个事情是这样的,现在所有的公司对于Java变量的命名规范,和数据库列名的命名规范要求并不一致!Java的变量命名规范是驼峰命名法,数据库的列名命名规范是下划线区分单词命名法,这样Java实体类和数据库列名不一致就成了一种常态。

为了尽量避免这种不一致造成的问题,我们可以在进行项目开发时参照阿里巴巴的开发规约,如下图所示:

现在你知道这个面试题该怎么解决及回答了吗?如果你还有其他问题,可以在评论区给我留言哦。

千锋教育Java入门全套视频教程(java核心技术,适合java零基础,Java自学必备)

相关推荐
Mr_hwt_1233 小时前
基于mybatis-plus动态数据源实现mysql集群读写分离和从库负载均衡教程(详细案例)
数据库·spring boot·mysql·mybatis·mysql集群
Z_z在努力16 小时前
【杂类】Spring 自动装配原理
java·spring·mybatis
little_xianzhong19 小时前
关于对逾期提醒的定时任务~改进完善
java·数据库·spring boot·spring·mybatis
MadPrinter1 天前
SpringBoot学习日记 Day11:博客系统核心功能深度开发
java·spring boot·后端·学习·spring·mybatis
奔跑吧邓邓子1 天前
【Java实战㉟】Spring Boot与MyBatis:数据库交互的进阶之旅
java·spring boot·实战·mybatis·数据库交互
lunzi_fly1 天前
【源码解读之 Mybatis】【基础篇】-- 第1篇:MyBatis 整体架构设计
java·mybatis
摸鱼仙人~1 天前
深入理解 MyBatis-Plus 的 `BaseMapper`
java·开发语言·mybatis
隔壁阿布都1 天前
spring boot + mybatis 使用线程池异步修改数据库数据
数据库·spring boot·mybatis
Mcband2 天前
MyBatis 拦截器让搞定监控、脱敏和权限控制
mybatis
╭╰4022 天前
苍穹外卖优化-续
java·spring·mybatis