JPA常用注解

@Entity
作用:设置一个类为实体类

Java代码   收藏代码
  1. @Entity  
  2. public class User {  
  3.   
  4. }  

 

@Table
作用:设置实体类对应的表,常与@Entity一起使用
参数:name制定表名,不写的话,为实体类的类名

Java代码   收藏代码
  1. @Entity  
  2. @Table(name = "tbl_user")  
  3. public class User {  
  4.   
  5. }  

@Id
作用:设置对象标识符

Java代码   收藏代码
  1. @Id  
  2. private Integer id;  

@GeneratedValue
作用:设置标识符的生成策略,常与@Id一起使用
参数:strategy指定具体的生成策略

 

方式一:@GeneratedValue(strategy=GenerationType.AUTO) 也是默认策略, 即写成@GeneratedValue也可。
类似于hibernate的native策略,生成方式取决于底层的数据库。

方式二:@GeneratedValue(strategy = GenerationType.IDENTITY)指定“自动增长”策略,适用于MySQL。

方式三:@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "seq_tbl_user")指定“序列”策略,使用于Oracle。
其中generator表示生成器的名字。
而且还要指定@SequenceGenerator(name = "seq_tbl_user", sequenceName = "seq_tbl_user", allocationSize = 1)注解配合使用
其中name指定生成器的名字(与generator的值一样),sequenceName指定数据库中定义序列的名字,allocationSize指定序列每次增长1


方式四:若不指定@GeneratedValue注解,则要手动提供Id值。user.setId();

Java代码   收藏代码
  1. @Id  
  2.     /** 自增 用于MySQL */  
  3.     @GeneratedValue(strategy = GenerationType.IDENTITY)  
  4.       
  5.     /** 序列 用于Oracle */  
  6.     @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "seq_tbl_user")  
  7.     @SequenceGenerator(name = "seq_tbl_user", sequenceName = "seq_tbl_user", allocationSize = 1)  
  8.       
  9.     /** 默认的 等同于@GeneratedValue */  
  10.     @GeneratedValue(strategy = GenerationType.AUTO)  
  11.     private Integer id;  

@Column
作用:设置列

 

参数:
name:指定列名
unique:指定唯一约束
nullable:指定是否允许为空
length:长度

 

Java代码   收藏代码
  1. @Column(name = "user_name", length = 255, nullable = true, unique = true)  
  2. private String name;  

设置默认值:

Java代码   收藏代码
  1. @Column(name = "user_name")  
  2. private String name = "monday";  

注意:若不写@Column注解,则一切使用@Column注解的默认值。

 

@Temporal
作用:设置日期时间

 

方式一:@Temporal(TemporalType.DATE)映射为日期 // birthday date (只有日期)
方式二:@Temporal(TemporalType.TIME)映射为日期 // birthday time (是有时间)
方式三:@Temporal(TemporalType.TIMESTAMP)映射为日期 //birthday datetime (日期+时间)

 

Java代码   收藏代码
  1. @Temporal(TemporalType.DATE)  
  2. private Date birthday;  

@Lob
作用:设置大数据类型

 

方式一:

Java代码   收藏代码
  1. @Lob  
  2. private String text;   //text longtext  

方式二:

Java代码   收藏代码
  1. @Lob  
  2. private byte[] image;   // image longblob  

@Enumerated
作用:设置枚举类型

 

方式一:

Java代码   收藏代码
  1. /** 保存字符串到数据库 */  
  2.     @Enumerated(EnumType.STRING)  
  3.     private Role role;  

方式二:

Java代码   收藏代码
  1. /** 保存整数到数据库 */  
  2.     @Enumerated(EnumType.ORDINAL)  
  3.     private Role role;  

上面定义的枚举:Role

Java代码   收藏代码
  1. /** 角色 */  
  2. public enum Role {  
  3.     游客, 会员, 管理员  
  4. }  

使用:

Java代码   收藏代码
  1. User user = new User();  
  2. user.setRole(Role.管理员);  

@Transient
作用:修饰的字段不会被持久化

Java代码   收藏代码
  1. @Transient  
  2. private String temp;   

这样也可以:

Java代码   收藏代码
  1. private transient String temp; 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: JPA是Java Persistence API的简称,是SUN公司引入的ORM规范,用于简化Java应用程序的持久化开发。JPA提供了一系列的注解,用于定义实体类与数据库表之间的映射关系。常用的JPA实体注解包括: 1. @Entity: 将Java类标记为JPA实体类,表示该类与数据库表进行映射。 2. @Table: 指定实体类对应的数据库表的名称。 3. @Id: 标记实体类的主键字段。 4. @GeneratedValue: 指定主键的生成策略,如自增长、UUID等。 5. @Column: 指定实体类属性与数据库表字段的映射关系。 6. @OneToOne: 定义一对一关系,用于关联两个实体类。 7. @OneToMany: 定义一对多关系,用于关联一个实体类与多个实体类。 8. @ManyToOne: 定义多对一关系,用于关联多个实体类与一个实体类。 9. @ManyToMany: 定义多对多关系,用于关联多个实体类与多个实体类。 以上是JPA常用的实体注解,通过使用这些注解,可以方便地定义实体类与数据库表之间的映射关系,简化开发过程。\[1\]\[3\] #### 引用[.reference_title] - *1* *3* [JPA 常用实体注解使用总结](https://blog.csdn.net/swebin/article/details/96458821)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [spring boot jpa学习:1.Model类的注释annatation](https://blog.csdn.net/sandalphon4869/article/details/105519101)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值