Mybatis(9):自定义映射resultMap

resultMap:一般用于处理字段名和属性名不一致问题,或者多对一 一对多问题

tips:

1. 数据库字段名一般命名未emp_id这种下划线,但是实体类一般采用驼峰命名,不能用下划线

  1. id在数据库中一般是自增主键,在业务中创建实体类也一般不赋值。int不赋值的情况下值为0,执行到数据库中id就为0,而Integer在不赋值的情况下为null,一般id为自增主键,数据更新到数据库中可以自动填充id。所以在实体类中,id数据类型用Integer(所以代码采用Integer)

  2. @Override是伪代码,表示重写(当然不写也可以),不过写上有如下好处:
    1、可以当注释用,方便阅读;
    2、编译器可以给你验证@Override下面的方法名是否是你父类中所有的,如果没有则报错。例如,你如果没写@Override,而你下面的方法名又写错了,这时你的编译器是可以编译通过的,因为编译器以为这个方法是你的子类中自己增加的方法。

举例:在重写父类的onCreate时,在方法前面加上@Override 系统可以帮你检查方法的正确性。
@Override
public void onCreate(Bundle savedInstanceState)

{.......}
这种写法是正确的,如果你写成:

@Override
public void oncreate(Bundle savedInstanceState)
{.......}
编译器会报如下错误:The method oncreate(Bundle) of type HelloWorld must override or implement a supertype method,以确保你正确重写onCreate方法(因为oncreate应该为onCreate)。而如果你不加@Override,则编译器将不会检测出错误,而是会认为你为子类定义了一个新方法:oncreate

JDBC查询采用:获取sql,然后反射进行获取对象的属性名,通过属性名获取属性

一、员工部门多对一具体实现具体实现

1.构建数据库两张表

2.实现具体类(员工类):实现有参/无参构造和toString方法

字段名和属性名不一致的处理方法:即如何根据下划线去定义驼峰

有两种方式:


只有这种格式的才可以被映射

3.使用resultMap自定义映射

property:属性,column:字段,javaType:属性类型,JDBCtype:字段类型

id:设置主键与字段的对应关系,result:设置普通字段与属性的映射关系

相关推荐
流星5211223 分钟前
GC 如何判断对象该回收?从可达性分析到回收时机的关键逻辑
java·jvm·笔记·学习·算法
csdn_aspnet3 分钟前
Java 圆台体积和表面积计算程序(Program for Volume and Surface area of Frustum of Cone)
java
sulikey4 分钟前
Qt 入门简洁笔记:从框架概念到开发环境搭建
开发语言·前端·c++·qt·前端框架·visual studio·qt框架
zzzsde9 分钟前
【C++】stack和queue:优先级队列的使用及底层原理
开发语言·c++
杯莫停丶9 分钟前
设计模式之:外观模式
java·设计模式·外观模式
乐之者v11 分钟前
Mac常用软件
java·1024程序员节
TDengine (老段)30 分钟前
TDengine 数据函数 ROUND 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·1024程序员节
TDengine (老段)33 分钟前
TDengine 数学函数 RAND 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
從南走到北33 分钟前
JAVA无人自助共享系统台球室源码自助开台约球交友系统源码小程序
java·微信·微信小程序·小程序·1024程序员节
是苏浙43 分钟前
零基础入门C语言之操作符详解2
c语言·开发语言