文章目录

  • 常用基本注解
  • @Entity【指定该实体类被JPA管理】
  • @Table【指定该实体类对应哪张表】
  • @Id【单个主键】
  • @IdClass【联合主键】
  • @Column【表示实体类属性对应数据库表的哪一字段(列)】
  • @OneToOne
  • 联合主键代码示例


常用基本注解

示例:创建一个表,表名称叫做user_info,我们创建出它的实体类为UserInfo,用这个表与实体类之间的关系来阐述JPA一些基本注解的使用。

import java.io.Serializable;
import lombok.Data;

@Data
public class UserInfo implements Serializable {
	
	private static final long serialVersionUID = 1L;

    /**
     * id
     */
    private String id;

    /**
     * 登录名
     */
    private String loginName;

    /**
     * 密码
     */
    private String password;

}

@Entity【指定该实体类被JPA管理】

@Entity注解所代表的意思是这个实体类是被JPA管理的实体类,它有两种用法:
第一种是直接添加该注解,默认的实体名称就是对应数据库表的名称;
第二种是添加该注解,指定该实体的名称,全局唯一;
一般都是直接使用第一种方法。

import java.io.Serializable;
import lombok.Data;
import javax.persistence.Entity;

@Data
@Entity // 第一种用法
// @Entity(name = "user_info") 第二种用法
public class UserInfo implements Serializable {...}

@Table【指定该实体类对应哪张表】

@Table注解是用在实体类上,用来表示这个实体类对应那张表,@Table中的name属性就是指定对应表的表名。

import java.io.Serializable;
import lombok.Data;
import javax.persistence.Entity;
import javax.persistence.Table;

@Data
@Entity
@Table(name="user_info")
public class UserInfo implements Serializable {...}

@Id【单个主键】

@Id注解是用在属性名上,表示这个属性名是一个主键,在这里id是主键,就在id上加上@Id注解。

import java.io.Serializable;
import lombok.Data;
import javax.persistence.Entity;
import javax.persistence.Table;
import javax.persistence.Id;

@Data
@Entity
@Table(name="user_info")
public class UserInfo implements Serializable {
	
	private static final long serialVersionUID = 1L;

    /**
     * id
     */
    @Id
    private String id;

    /**
     * 登录名
     */
    private String loginName;

    /**
     * 密码
     */
    private String password;

}

@IdClass【联合主键】

@IdClass注解的作用是当你这张表有联合主键时,就可以用它指定一个实体类,表示有哪些联合主键,先做一个示例,快速知道这个的用法。
假设,user_info表中的主键分别是idloginName,那么就需要定义一个实体类去表示出有哪些属性是主键,创建出UserInfoKey实体类去表示UserInfo(user_info)的联合主键,下面为示例展示:

UserInfo实体类:

import java.io.Serializable;
import lombok.Data;
import javax.persistence.Entity;
import javax.persistence.Table;
import javax.persistence.Id;
import javax.persistence.IdClass;

@Data
@Entity
@IdClass(UserInfoKey.class)
@Table(name="user_info")
public class UserInfo implements Serializable {
	
	private static final long serialVersionUID = 1L;

    /**
     * id
     */
    private String id;

    /**
     * 登录名
     */
    private String loginName;

    /**
     * 密码
     */
    private String password;

}

UserInfoKey实体类:

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;

@Data
@NoArgsConstructor
@AllArgsConstructor
public class UserInfoKey implements Serializable {
    private String id;
    private String loginName;
}

@Column【表示实体类属性对应数据库表的哪一字段(列)】

@Column注解是用在实体类属性上,表示这个实体类属性是对应数据库表的哪一字段(列),如果实体类属性与数据库表中的字段(列)一直,就不需要添加@Column注解。

import java.io.Serializable;
import lombok.Data;
import javax.persistence.Entity;
import javax.persistence.Table;
import javax.persistence.Id;
import javax.persistence.Column;

@Data
@Entity
@Table(name="user_info")
public class UserInfo implements Serializable {
	
	private static final long serialVersionUID = 1L;

    /**
     * id
     */
    @Id
    private String id;

    /**
     * 登录名
     */
    @Column(name = "login_name")
    private String loginName;

    /**
     * 密码
     */
    private String password;

}

@OneToOne

@OneToOne注解表示A数据实体与B数据实体一对一的关系。

fetch属性定义:从数据库获取数据的策略。
默认值是EAGER,表示数据必须被立即获取。另一种选择是LAZY,表示数据只有在需要时才被获取,切记:如果是SpringBoot使用LAZY模式,一定要在查询方法上加上@Transactional(readOnly = true),因为需要让SqlSession一直存在。

cascade属性定义:级联操作的类型。
级联操作是指当父实体发生变化时,子实体也跟着变化,例如,当删除父实体时,子实体也被删除。
级联操作的类型有ALL(所有操作)、PERSIST(持久化操作)、MERGE(合并操作)、REMOVE(删除操作)和REFRESH(刷新操作)。

optional属性定义:关联是否可选,默认值是true,表示关联可以为空。如果设置为false,则表示关联必须存在 。

orphanRemoval属性定义:是否移除孤儿记录。默认值是false,表示不移除孤儿记录。如果设置为true,则表示当父实体不再引用子实体时,子实体将被删除 。

mappedB属性定义:是关系的拥有方。拥有方是指具有连接列或连接表的那一方。mappedBy属性指定了另一方中与此关系相对应的属性名。



联合主键代码示例

接下来,在这里给一下代码示例:
user_info 用户表,属性有:tenant_id(租户Id)、id、login_name、password,其中,tenant_id和id是联合主键;
user_extend_info 用户扩展信息表,属性有:tenant_id(租户Id)、iduser_id、ID_card,其中,tenant_id和id是联合主键,user_id和tenant_id组成与用户表的id和tenant_id相关联;

import java.io.Serializable;
import lombok.Data;
import javax.persistence.*;

@Data
@Entity
@IdClass(CommonKey.class)
@Table(name="user_info")
public class UserInfo implements Serializable {

    /**
     * id
     */
    @Id
    @Column(name = "id")
    private String id;

    /**
     * 租户Id
     */
    @Id
    @Column(name = "tenant_id")
    private String tenantId;

    /**
     * 登录名
     */
    @Column(name = "login_name")
    private String loginName;

    /**
     * 密码
     */
    @Column(name = "password")
    private String password;

    @OneToOne(cascade = CascadeType.ALL)
    @JoinColumns({
            @JoinColumn(name = "user_id", referencedColumnName = "id", insertable = false, updatable = false),
            @JoinColumn(name = "tenant_id", referencedColumnName = "tenant_id", insertable = false, updatable = false)
    })
    private UserExtendInfo userExtendInfo;
}
import java.io.Serializable;
import lombok.Data;
import javax.persistence.*;

@Data
@Entity
@IdClass(CommonKey.class)
@Table(name="user_extend_info")
public class UserExtendInfo implements Serializable {

    /**
     * id
     */
    @Id
    @Column(name = "id", insertable = false, updatable = false)
    private String id;

    /**
     * 租户Id
     */
    @Id
    @Column(name = "tenant_id", insertable = false, updatable = false)
    private String tenantId;

    /**
     * 用户Id
     */
    @Column(name = "user_Id")
    private String userId;

    /**
     * 身份证号
     */
    @Column(name = "ID_card")
    private String IDCard;


}

CommonKey实体类:

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;

@Data
@NoArgsConstructor
@AllArgsConstructor
public class CommonKey implements Serializable {
    private String id;
    private String tenantId;
}






End