JPA 实体映射

一、实体基本映射

 1 /*
 2 * @Entity:将领域对象标注为一个实体,表示保存到数据库中
 3 * @@Table:保存到数据库中表名,默认表名为类名,可通过name属性命名
 4 *
 5 * */
 6 @Entity
 7 @Table(name="t_user")
 8 public class User {
 9
10
11     @Id //主键
12     @GeneratedValue // JPA自动选择合适的生成策略
13     @Column(name="id_") //列名,默认为属性名,可通过name属性指定列名
14     private Integer id;
15
16
17 /*    @Id
18     @GeneratedValue(generator="uuidGenerator")
19     @GenericGenerator(name="uuidGenerator",strategy="uuid") //UUID生成策略
20     @Column(name="id_",length=32)
21     private String id;*/
22
23
24 /*    @Id
25     @GeneratedValue(strategy = GenerationType.AUTO) //JPA自动选择合适的策略,是默认选项
26     @Column(name="id_")
27     private Integer id;*/
28
29
30     /*
31      *
32     @Id
33     @GeneratedValue(strategy=GenerationType.IDENTITY) //表示自增键字段,oracle不支持这种方式
34     @Column(name="id_")
35     private Integer id;*/
36
37
38     /*
39     @Id
40     @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "idGenerator") //通过序列产生主键,通过@SequenceGenerator注解指定序列列名,mysql不支持这种方式
41     @SequenceGenerator(name = "idGenerator",sequenceName="mySeq",allocationSize=1)
42     @Column(name="id_")
43     private Integer id;*/
44
45     /*
46     @Id
47     @GeneratedValue(strategy = GenerationType.TABLE, generator = "userGenerator")//通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植。
48     @TableGenerator(name = "userGenerator",table="pk_generator",
49                     pkColumnName="gen_name",
50                     valueColumnName="gen_value",
51                     pkColumnValue="user_pk",
52                     initialValue=0,
53                     allocationSize=1)
54     @Column(name="id_")
55     private Integer id;
56     */
57
58     //length:字段的长度;nullable:是否允许为空;unique:指定是否唯一性;insertable updatable:指定该字段是否插入或修改到数据库表中,对应表中需通过columnDefinition指定默认值;
59     @Column(name="name_", length=60, nullable=false,unique=true,insertable=false,updatable=false)
60     private String name;
61
62     @Column(name="address_", length=60, nullable=false)
63     private String address;
64
65     @Column(name="phone_", length=11, nullable=true,columnDefinition="CHAR(10) default ‘000‘") //columnDefinition:底层数据库的字段类型,根据不同数据库配置
66     private String phone;
67
68     @Column(name="inCome_", precision=12, scale=2) //precision:浮点型总长度;scale:小数的位数
69     private BigDecimal inCome;
70
71     @Temporal(TemporalType.DATE) //如果属性是时间类型,因为数据表对时间类型有更严格的划分,所以必须指定具体时间类型。
72     private Date birthday;
73     //Date 日期型,精确到年月日,例如“2008-08-08”
74     //Time 时间型,精确到时分秒,例如“20:00:00”
75     //Timestamp 时间戳,精确到纳秒,例如“2008-08-08 20:00:00.000000001”
76
77     @Lob
78     @Column(name="pic_")
79     @Basic(fetch=FetchType.LAZY)
80     private byte[] pic;
81
82     @Lob
83     @Column(name="note_")
84     @Basic(fetch=FetchType.LAZY)
85     private String note;
86
87     ...........
88 }    

二、实体表间映射

1、一对一实体映射:人与地址

 1 @Entity
 2 public class Person {
 3     @Id
 4     @GeneratedValue(strategy = GenerationType.AUTO)
 5     private Long id;
 6     private String name;
 7     private int age;
 8     //@OneToOne 一对一映射,级联操作,通过cascade属性设置;懒加载操作,通过fetch属性设置
 9     @OneToOne(cascade={CascadeType.REFRESH,CascadeType.REMOVE},fetch=FetchType.LAZY)
10     //@JoinColumn:Person中address字段对应的"address_id"表示Address中"aid"字段,即外键关系;如自动建表,@JoinColum注解可省略
11     @JoinColumn(name="address_id",referencedColumnName="aid")
12     //@JoinColumns(value={@JoinColumn(name="address_id",referencedColumnName="aid"),@JoinColumn(name="address_id2",referencedColumnName="aid2")})
13     private Address address;
14 ...........
15 }
 1 @Entity
 2 public class Address {
 3
 4     @Id
 5     @GeneratedValue(strategy = GenerationType.AUTO)
 6     private Long aid;
 7     private String street;
 8     private String city;
 9     private String country;
10
11
12     @Column(name="aid_")
13     public Long getAid() {
14         return aid;
15     }
16 .............
17 }

2、一对多实体映射:员工表与部门表

 1 @Entity
 2 public class Depart {
 3     @Id
 4     @GeneratedValue
 5     private Long did;
 6     private String name;
 7
 8     @OneToMany //一对多映射
 9     /*
10         通过中间表关联
11       @JoinTable 配置中间表信息,name:中间表名;
12        joinColumns:部门表与中间表间的关系,"depart_id"部门表中的主键字段作为中间表中外键(did)字段
13        inverseJoinColumns:被拥有者,即员工表与中间表的关系
14     */
15     @JoinTable(name = "depart_employee",
16         joinColumns = @JoinColumn(name = "depart_id",referencedColumnName="did"),
17         inverseJoinColumns = @JoinColumn(name = "employee_id",referencedColumnName="eid"))
18     /*
19         通过设置外键关联
20         设置"did"字段做为另一方的外键"depart_id"
21     @JoinColumn(name="depart_id",referencedColumnName="did")
22     */
23     private List<Employee> employees;
24 .....
25 }
1 @Entity
2 public class Employee {
3     @Id
4     @GeneratedValue(strategy = GenerationType.AUTO)
5     private Long eid;
6     private String  name;
7 .......
8 }

3、多对多实体映射:老师与学生

 1 @Entity
 2 public class Teacher {
 3
 4     @Id
 5     @GeneratedValue(strategy = GenerationType.AUTO)
 6     private Long tid;
 7     private String name;
 8     private Boolean gender;
 9     private int age;
10     private int height;
11     @ManyToMany
12     @JoinTable(name = "teacher_student",
13         joinColumns = @JoinColumn(name = "teacher_id",referencedColumnName="tid"),
14         inverseJoinColumns = @JoinColumn(name = "student_id",referencedColumnName="sid"))
15     private List<Student> students;
16 ..........
17 }
 1 @Entity
 2 public class Student {
 3
 4     @Id
 5     @GeneratedValue(strategy = GenerationType.AUTO)
 6     private Long sid;
 7     private String name;
 8     private Boolean gender;
 9     private int age;
10     private int height;
11
12     @ManyToMany(mappedBy = "students")
13     private List<Teacher> teachers;
14 ...............
15 }

原文地址:https://www.cnblogs.com/gdwkong/p/8608672.html

时间: 2024-11-06 14:37:17

JPA 实体映射的相关文章

Hibernate之jpa实体映射的三种继承关系

在JPA中,实体继承关系的映射策略共有三种:单表继承策略(table per class).Joined策略(table per subclass)和Table_PER_Class策略. 1.单表继承策略 单表继承策略,父类实体和子类实体共用一张数据库表,在表中通过一列辨别字段来区别不同类别的实体.具体做法如下: a.在父类实体的@Entity注解下添加如下的注解: @Inheritance(Strategy=InheritanceType.SINGLE_TABLE)@Discriminator

JPA实体基本映射

1.前言 JPA可以使用XML映射文件来管理实体与数据表之间的映射关系,但在实际开发中,绝大部分情况都是采用Annotation来管理实体和数据表的映射关系.本篇着重来讲解一下JPA中采用注解形式来映射实体. 2.JPA属性注入 2.1.常用注解 @Entity:被该注解修饰的POJO就是一个实体 @Table:该注解反应的是所映射的一个表 @Column:该字段用来修饰多要描述的属性 [email protected] 在默认情况下,实体类的Field会自动映射到数据表的数据列,如果不想映射的

hibernate的实体映射(一对一)

Hibernate的实体映射的主要任务就是实现数据库关系表与持久化类之间的映射,其关系如图: 双向映射一对一关联关系,通过唯一外键方式进行一对一关联映射,就是一个表的外键和另一个表的唯一主键对应形成一对一映射关系. 例如,以下例子,社团与社团负责人(社长),两者之间是一对一的关联关系: 持久化类association.java: public class Association implements java.io.Serializable{     private Integer id;   

使用Fluent API进行实体映射【Code-First系列】

现在,我们来学习怎么使用Fluent API来配置实体. 一.配置默认的数据表Schema Student实体 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace EF4 { public class Student { public int StudentID { get; set; } publ

Hibernate(三)结构-配置文件-实体映射及配置文件

一.体系结构 SessionFactory:属于单一数据库的编译过的映射文件的一个线程安全的,不可变的缓存快照.Session的工厂.有可能持有一个可选的数据缓存可以进程级别或者群级别保存可以在事务中重用数据. 会话,Session:单线程,生命期短促的对象,代表应用程序和持久化层之间的一次对话.封装了一个JDDBC连接,它也是Transaction的工厂,保存有必须持久化对象的缓存,用于遍历对象,或者通过标识符查找对象. 持久化对象(Persistent Object)及其集合(Collect

Hibernate实体映射技巧总结

初学者有没有感觉在写Hibernate实习映射的时候,被各种的many-to-one set one-to-many搞乱了头脑呢? 下面只需要三部,轻轻松松搞定. 1,写注释 格式为:(1?)属性,是本类与(2?)的(3?)关系. <span style="font-size:14px;">例如: <!-- users属性,本类与User的一对多 --> <!-- parent属性,本类与Department的多对一 --> <!-- role

EntityFrameWork实体映射

在ORM的实体框架中多为继承,关联等 在Hibernater中关联的实体,需要配置 xml文件来维护不同实体的关系 而在EF中这这是通过可视化的图形操作来控制之间的关系的:如下图 关联映射 如已经通过PowerDeesigner画好了实体间的关系 ,实体关系在转成物理模型导入数据库.通过EF的model模型从数据库导入图2 选择好数据库,选择好实体框架,注意这里的框架是和Framework对应的 重点来了 我们看到 有(在模型中包括外键列)若选择该列,这就会在有关联关系的实体中添加外键列.则在添

Hibernate实体映射文件多对多等关系简单应用技巧

第一步,写注释: <!--xx属性,本类与Yy(类)的多对一 --> <!--xx属性,本类与Yy(类)的一对多 --> <!--xx属性,本类与Yy(类)的多对多 --> <!--xx属性,本类与Yy(类)的一对一 --> 第二部,拷模版 <!--xx属性,本类与Yy(类)的多对一 --> <many-to-one name="" class="" column="">&l

开源实体映射框架EmitMapper介绍

开源实体映射框架EmitMapper介绍 综述 EmitMapper是一个开源实体映射框架,地址:http://emitmapper.codeplex.com/. EmitMapper映射效率比较高,接近硬编码.EmitMapper采用emit方式在运行时动态生成IL,而其他映射框架多是采用反射机制.此外EmitMapper最大限度地减少了拆箱装箱操作和映射过程中的额外的调用. EmitMapper支持.net的所有平台:Framework 3.5.Microsoft Silverlight 3