JPA常用注解笔记

JPA 有什么用?

将Java对象映射到数据库表(反之亦然)称为对象关系映射(ORM)。 JPA 是ORM的一种可能方法。 通过JPA,开发人员可以将关系数据库中的数据映射,存储,更新和检索到Java对象,反之亦然。
JPA(Java Persistence API)是EJB(Enterprise JavaBeans)3.0规范的一部分,提供了一种对象关系映射方法,允许您以标准,可移植的声明方式,将Java对象映射到关系数据库表。
JPA 流行的实现有Hibernate,EclipseLink和Apache OpenJPA。

常用的JPA注解及意义。

  • @Entity
    使用@Entity批注将POJO(plain old Java object )类指定为实体,使其符合JPA服务的条件。 也就是说在使用任何其他JPA注释之前,必须将POJO类指定为实体。
@Entity
public class Student implements Serializable {
    ...
}
  • @Table
    name 参数用于指定数据库的表名,不指定则默认表名和实体名相同。
    schema 参数用于指定数据库模式名,不指定则为默认数据库模式。
@Entity
@Table(name = "SDT", schema = "USER")
public class Student implements Serializable {
   ...
}
  • @Id
    将某个字段指定为实体的主键。
@Entity
@Table(name = "SDT", schema = "USER")
public class Student implements Serializable {
   @Id
   private int id;
   ...
}
  • @GeneratedValue
    如果希望JPA提供和管理实体标识符,请使用@GeneratedValue批注。
    如下所示,strategy = GenerationType.AUTO 指的是JPA会选择最适合底层数据库的主键生成器。
@Entity
@Table(name = "SDT", schema = "USER")
public class Student implements Serializable {
  @Id
  @GeneratedValue(strategy = GenerationType.AUTO)
  private int id;
  ...
}
  • @Column
    JPA假定实体的每个持久属性都存储在数据库表列中,该列的名称与持久字段或属性的名称相匹配。如下所示,如果表字段名和类的属性名不匹配则通过name属性指定。
@Entity
@Table(name = "SDT", schema = "USER")
public class Student implements Serializable {
   @Id
   @GeneratedValue(strategy = GenerationType.AUTO)
   @Column(name="STD_ID")
   private int id;
   ...
}
  • @Transient
    默认情况下,JPA假定实体的所有字段都是持久化的。使用*@Transient*批注指定非持久化实体的字段或属性,例如,在运行时使用但不属于实体状态的字段或属性。
@Entity
@Table(name = "SDT", schema = "USER")
public class Student implements Serializable {
   @Id
   @GeneratedValue(strategy = GenerationType.AUTO)
   @Column(name="STD_ID")
   private int id;
   
	@Transient 
	private Session currentSession;
   ...
}

JPA的注解有大几十个,并且有很多注解中有许多属性可配置。这里不做详细讲解,像@OneToOne、@ManyToOne、@OneToMany、@ManyToMany、@OrderBy等等都是非常实用的。以后有时间可以再做梳理。如果大家有兴趣可以去官网查看JPA Annotation Reference

  • 1
    点赞
  • 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、付费专栏及课程。

余额充值