当前位置: 首页 > news >正文

通用Mapper的四个常见注解

四个常见注解

1、@Table

作用:建立实体类数据库表之间的对应关系。

默认规则:实体类类名首字母小写作为表名,如 Employee -> employee 表

用法:在 @Table 注解的 name 属性中指定目标数据库的表名;

案例:

2、@Column

作用:建立实体类字段数据库表字段之间的对应关系

默认规则:实体类字段,驼峰式命名,数据库表字段,使用"_" 区分各个单词;

用法:在 @Column 注解的 name 属性中指定目标字段的字段名

案例:

3、@Id

通用 Mapper 在执行 xxxByPrimaryKey(key) 方法时,有两种情况:

情况 1:没有使用 @Id 注解明确指定主键字段

SELECT emp_id,emp_name,emp_salary,emp_age FROM tabple_emp 
WHERE emp_id = ? AND emp_name = ? AND emp_salary = ? AND emp_age = ?

之所以会生成上面的 where 子句是因为通用 Mapper 将实体类的所有字段都拿来放在一起作为联合主键。

情况 2:使用@Id 注解明确标记和数据库表中主键字段对应的实体类字段

如:

SELECT emp_id,emp_name,emp_salary,emp_age FROM tabple_emp WHERE emp_id = ?

注意:如果是多个字段作为联合主键,需要在每个字段上面都加上 @Id 注解。

4、@GeneratedValue

作用:让通用 Mapper 在执行 insert 操作之后将数据库自动生成的主键值回写到实体类对象中。

自增主键用法(MySQL):

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer empId;

序列主键用法(Oracle)

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY, generator="select SEQ_ID.nextval from dual")
private Integer empId;

5、@Transient

一般实体类中字段和数据库表中字段一一对应的,但是也有很多情况会在实体类中增加一些额外的属性,这种情况,需要使用@Transient 注解告诉通用 Mapper 这不是表中的字段

对于类中复杂对象,以及 Map、List 等属性不需要配置这个注解

配置实例:

@Transient
private String otherThings; //非数据库字段

 


 

代码举例 

import lombok.Data;import javax.persistence.Id;
import javax.persistence.Table;@Data
@Table(name = "user")
public class User {@Idprivate Integer id;private String name;private Integer age;
}

http://www.lryc.cn/news/113706.html

相关文章:

  • 二进制安装K8S(单Master集群架构)
  • 基于java汽车销售分析与管理系统设计与实现
  • Glass指纹识别工具,多线程Web指纹识别工具-Chunsou
  • BIO,NIO,AIO总结
  • [腾讯云Cloud Studio实战训练营]基于Cloud Studio完成图书管理系统
  • (二)Node.js 基础模块
  • AUC及其拓展GAUC
  • 【CSS】CSS 选择器
  • 2023-08-07力扣今日四题-好题
  • Packet Tracer - IPv4 和 IPv6 编址故障排除
  • PHP国外在线教育系统源码 在线课程系统源码 直播课程系统源码提供在线课程,现场课程,测验
  • Abaqus 中最常用的子程序有哪些 硕迪科技
  • 容器——3.Collection 子接口之 Set
  • 将整数,结构体,结构体数组,链表写到文件
  • UNIX基础知识:UNIX体系结构、登录、文件和目录、输入和输出、程序和进程、出错处理、用户标识、信号、时间值、系统调用和库函数
  • IDEA2021.3.1-优化设置IDEA2021.3.1-优化设置、快捷方式改为eclipse、快捷键等
  • 使用C#的窗体显示与隐藏动画效果方案 - 开源研究系列文章
  • 09_Vue3中的 toRef 和 toRefs
  • JAVA获取视频音频时长 文件大小 MultipartFileUtil和file转换
  • 刷题笔记 day9
  • 小白解密ChatGPT大模型训练;Meta开源生成式AI工具AudioCraft
  • 1 swagger简单案例
  • Flutter写一个android底部导航栏框架
  • 关于自动化测试用例失败重试的一些思考
  • JS逆向之顶像滑块
  • 【css】textarea-通过resize:none 禁止拖动设置大小
  • Linux内核学习小结
  • 八、ESP32控制8x8点阵屏
  • 使用gitee创建远程maven仓库
  • 基于C#的应用程序单例唯一运行的完美解决方案 - 开源研究系列文章