http://www.blogjava.net/zJun/archive/2007/01/24/95747.html

@transient 忽略该方法

一、

@Entity:通过@Entity注解将一个类声明为一个实体bean

@Table(name=”t_Husband”):通过 @Table注解可以为实体bean映射指定表,name属性表示实体所对应表的名称,如果没有定义 @Table,那么系统自动使用默认值:实体的类名(不带包名)

二、

@Id:用于标记属性的主键

@GeneratedValue(默认取值anto,ID生成策略)

三、

@Column(name=”wifeid”):表示持久化属性所映射表中的字段,如果属性名与表中的字段名相同,则可以省略

四、联合主键

  当entity class使用复合主键时,需要定义一个类作为id class。id class必须符合以下要求:类必须声明为public,并提供一个声明为public的空构造函数。必须实现Serializable接,覆写 equals()和hashCode()方法。entity class的所有id field在id class都要定义,且类型一样。

在类名上@Entity@IdClass(TeacherPK.class)

在联合主键的两个属性上分别@Id@Id

public class EmployeePK implements java.io.Serializable{
      
String empName;
      
Integer empAge;
       public
EmployeePK(){}
       public
boolean equals(Object obj){ ......}
      
public int hashCode(){......}
   
}

@IdClass(EmployeePK.class)
   
@Entity
   
public class Employee {
       
@Id String empName;
       
@Id Integer empAge;
   
}

五、关联关系(在getter方法上加入以下Annotation)

1、1 to 1

(1)单向外键:

Husband中:

private Wife wife;

@OneToOne

@JoinColumn(name="wifeid")-->设置Husband表中的对应字段名,可以省略,默认字段名为类名_主键名

(2)双向外键:

Husband中:

private Wife wife;

@OneToOne

@JoinColumn(name="wifeid")-->设置Husband表中的对应字段名,可以省略,默认字段名为类名_主键名

Wife中:

private Husband husband;

@OneToOne(mappedBy="wife")-->wife为Husband类中的属性

(3)联合主键:(wife类中的id和name作为联合主键)

Husband中:

private Wife wife;

@OneToOne

@JoinColumns({     -->设置Husband表中的对应字段名,可以省略,默认字段名为类名_主键名

        @JoinColumn(name="wifeid", referencedColumnName="id"),

     @JoinColumn(name="wifename", referencedColumnName="name")

        })

(4)组件映射:(Wife作为Husband的一部分,两个类一张表)

Husband中:

private Wife wife;

@Embedded

@Column-->可略

Wife中:

不需要@Entity@Id

2、1 to N , N to 1

设计:在“多”方加入外键,而不是在“一”方加入外键。下面三种方式生成的表是一样的。

(1)多对一单向

User中:

private Group group;

@ManyToOne

@JoinColumn-->可略

(2)一对多单向(在多方的表中加入外键)

Group中:

private User<Set> users = new HashSet<User>();

@OneToMany

@JoinColumn(name="groupid")-->避免产生中间表

(3)双向(应用少)

User中:

private Group group;

@ManyToOne

@JoinColumn-->可略

Group中:

private User<Set> users = new HashSet<User>();

@OneToMany(mappedBy="group")-->User类中的group属性

3、N to N

设计:加入中间表。下面两种方式生成的表一样。

(1)单向

Teacher中:

private Set<Student> students = new HashSet<Student>();

@ManyToMany

@JoinTable(          -->修改中间表名及字段名

      name=”teacher_student”,

     joinColumns=@JoinColumn(name="t_ID", referencedColumnName="id"),

      inverseJoinColumns=@JoinColumn(name="s_ID", referencedColumnName="id")

      )

(2)双向(应用少)

Teacher中同上;

Student中:

private Set<Teacher> teachers = new HashSet<Teacher>();

@ManyToMany(mappedBy="students")

4、在@OneToOne@OneToMany@ManyToOne@ManyToMany后面的括号中可以加入两个属性:

cascade=CascadeType.ALL-->增删改数据时

fetch=FetchType.LAZY/EARGER-->读数据时

六、

@JoinColumn

如果在entity class的field上定义了关系(one2one或one2many等),我们通过JoinColumn来定义关系的属性。

name:列名。

referencedColumnName:该列指向列的列名(建表时该列作为外键列指向关系另一端的指定列)

unique: 是否唯一

nullable: 是否允许为空

insertable: 是否允许插入

updatable: 是否允许更新

columnDefinition: 定义建表时创建此列的DDL

secondaryTable: 从表名。如果此列不建在主表上(默认建在主表),该属性定义该列所在从表的名字。

下面的代码说明Husband和Wife是一对一关系。在Husband对应的映射表建一个名为wifeid的列,该列作为外键指向Wife对应表中的主键id。

public class Husband{

private
Wife wife;

@OneToOne

@JoinColumn(name="wifeid")

public
Wife getWife () {

return
wife;

}

7、

@JoinColumns

如果在entity class的field上定义了关系(one2one或one2many等),并且关系存在多个JoinColumn,用JoinColumns定义多个JoinColumn的属性。

元数据属性说明:

value: 定义JoinColumn数组,指定每个JoinColumn的属性。

下面的代码说明Husband和Wife是一对一关系。在Husband对应的映射表建两列,一个名为wifeid的列,该列作为外键指向Wife对应表中的主键id;另一个为wifename的列,该列作为外键指向Wife对应表中的主键name。

public class Husband{

private
Wife wife;

@OneToOne

@JoinColumns({

@JoinColumn(name="wifeid",
referencedColumnName="id"),

@JoinColumn(name="wifename",
referencedColumnName="name")

})

public
Wife getWife () {

return
wife;

}

8、

@JoinTable

JoinTable在many-to-many关系的所有者一边定义。如果没有定义JoinTable,使用JoinTable的默认值。

元数据属性说明:

  • name:这个join table的名字。
  • joinColumns:定义指向所有者主表的外键列,数据类型是JoinColumn数组。
  • inverseJoinColumns:定义指向非所有者主表的外键列,数据类型是JoinColumn数组。

下面的teacher类代码定义了一个连接表teacher和student的join table。join table的表名是teacher_student,包含两个外键,一个外键是t_ID,指向表teacher的主键ID,另一个外键是s_ID,指向表student的主键ID。其中referencedColumnName可以省略。

public class Teacher{

 private Set<Student> students = new HashSer<Student>();

 @ManyToMany

@JoinTable(

name=”teacher_student”,

joinColumns=@JoinColumn(name="t_ID",
referencedColumnName="id"),

inverseJoinColumns=@JoinColumn(name="s_ID",
referencedColumnName="id")

)

  public  Set<Student> getStudents(){

    return students;

  }

JPA的常用Annotation的更多相关文章

  1. jpa基于按annotation的hibernate主键生成策略

    JPA注解持久化类很方便,需要jar包:ejb3-persistence.jar下载 一.JPA通用策略生成器 通过annotation来映射hibernate实体的,基于annotation的hib ...

  2. 3、JPA一些常用的注解

    常用注解有下面这些: ①:@Entity.@Table.@Id.@GeneratedValue.@Column.@Basic ②:@Transient 用于忽略某个属性,而不对该属性进行持久化操作 ③ ...

  3. JPA之常用 基本注解

    1.常用基本注解 @Entity @Table @Basic @Column @GeneratedValue @Id 2.特殊注解 @Transient @Temporal 用 table 来生成主键 ...

  4. Spring Data JPA 中常用注解

    一.java对象与数据库字段转化 1.@Entity:标识实体类是JPA实体,告诉JPA在程序运行时生成实体类对应表 2.@Table:设置实体类在数据库所对应的表名 3.@Id:标识类里所在变量为主 ...

  5. 17 Spring Data JPA的常用接口分析

    思考 在客户的案例中,我们发现在自定义的CustomerDao中,并没有提供任何方法就可以使用其中的很多方法,那么这些方法究竟是怎么来的呢?答案很简单,对于我们自定义的Dao接口,由于继承了JpaRe ...

  6. Spring常用annotation标签

    @Service @Scope @Transactional @Autowired @Qualifier @PostConstruct @PreDestroy

  7. Hibernate常用Annotation标签说明

    @ javax.persistence.Entity 实体类定义,该标签表示当前类是一个Hibernate的数据库实体,对应着数据库中的某个表 位置:用于类级别 参数:无 样例:@Entity 注意: ...

  8. JPA常用注解

    JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中.        JPA由EJB 3.0软件专家 ...

  9. JPA常用注解(转载)

    转自:http://blog.csdn.net/wanghuan203/article/details/8698102 JPA全称Java Persistence API.JPA通过JDK 5.0注解 ...

随机推荐

  1. 论文阅读 | Real-Time Adversarial Attacks

    摘要 以前的对抗攻击关注于静态输入,这些方法对流输入的目标模型并不适用.攻击者只能通过观察过去样本点在剩余样本点中添加扰动. 这篇文章提出了针对于具有流输入的机器学习模型的实时对抗攻击. 1 介绍 在 ...

  2. 第四周课程总结&实验报告(二)

    Java实验报告(二) 实验二 Java简单类与对象 一. 实验目的 (1) 掌握类的定义,熟悉属性.构造函数.方法的作用,掌握用类作为类型声明变量和方法返回值: (2) 理解类和对象的区别,掌握构造 ...

  3. 客户A数据统计

    -------------------------------------------------- --数据准备 /*将数据调入临时表,对advalues进行计算,并将月份更新到字段int1 */ ...

  4. 解决Eclipse发布到Tomcat丢失依赖jar包的问题

    解决Eclipse发布到Tomcat丢失依赖jar包的问题 如果jar文件是以外部依赖的形式导入的.Eclipse将web项目发布到Tomcat时,是不会自动发布这些依赖的. 可以通过Eclipse在 ...

  5. 【pytorch】学习笔记(三)-激励函数

    [pytorch]学习笔记-激励函数 学习自:莫烦python 什么是激励函数 一句话概括 Activation: 就是让神经网络可以描述非线性问题的步骤, 是神经网络变得更强大 1.激活函数是用来加 ...

  6. SSM @Autowired注入失败

    1, Intellij IDEA中Mybatis Mapper自动注入警告的6种解决方案 https://blog.csdn.net/weixin_30945319/article/details/9 ...

  7. 通过PlayBook部署Zabbix

    编写Linux初始化剧本 初始化剧本环节,主要用户实现关闭Selinux关闭防火墙,一起配置一下阿里云的YUM源地址,和安装EPEL源,为后期的zabbix安装做好铺垫工作. 1.在安装Zabbix之 ...

  8. qt treaview项checkbox样式

    QTreeView::indicator:enabled:checked { /** 指示器 - 选中 **/ image: url(yzfx/checkbox_checked.png);}QTree ...

  9. 部署etcd集群

    部署etcd集群 第一步:先拉取etcd二进制压缩包 wget https://github.com/coreos/etcd/releases/download/v3.3.2/etcd-v3.3.2- ...

  10. 05 Python网络爬虫的数据解析方式

    一.爬虫数据解析的流程 1.指定url 2.基于requests模块发起请求 3.获取响应中的数据 4.数据解析 5.进行持久化存储 二.解析方法 (1)正则解析 (2)bs4解析 (3)xpath解 ...