属性级别注解
添加方式:
写在属性字段上面
写在属性的get访问器的上面
@Id
必须,定义了映射到数据库表的主键的属性,一个实体类可以有一个或者多个属性被映射为主键,可置于主键属性或者getXxx()前,注意:如果有多个属性定义为主键属性,该实体类必须实现serializable接口
@SequenceGenerator
@GeneratedValue
@GeneratedValue(strategy=GenerationType,generator=""):可选,用于定义主键生成策略
strategy表示主键生成策略,取值有:
GenerationType.AUTO:根据底层数据库自动选择(默认)
GenerationType.INDENTITY:根据数据库的Identity字段生成
GenerationType.SEQUENCE:使用Sequence来决定主键的取值
GenerationType.TABLE:使用指定表来决定主键取值,结合@TableGenerator使用
@Column
@Column-可将属性映射到列,使用该注解来覆盖默认值,@Column描述了数据库表中该字段的详细定义,这对于根据JPA
注解生成数据库表结构的工具非常有作用。
常用属性:
name:可选,表示数据库表中该字段的名称,默认情形属性名称一致
nullable:可选,表示该字段是否允许为null,默认为true
unique:可选,表示该字段是否为唯一标识,默认为false
length:可选,表示该字段的大小,仅对String类型的字段有效,默认值225,主键不能使用默认值
insertable:可选,表示在ORM框架执行插入操作时,该字段是否应出现INSERTRT语句中,默认为true
updateable:可选,表示在ORM框架执行更新操作时,该字段是否应该出现在UPDATE语句中,默认为true。对于已经创建
就不可以更改的字段,该属性非常有用
@Embedded
@Embedded是注释属性的,表示该属性的类是嵌入类。
注意:同时嵌入类也必须标注@Embeddable注解
@EmbeddedId
@EmbeddedId使用嵌入式主键类实现复合主键
注意:嵌入式主键类必须实现Serializable接口、必须有默认的public无参数的构造方法、必须覆盖equals和hashCode方法
@Lob
@Version
@Basic
@Transient
可选,表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性,如果一个属性并非数据库表的字段映射,就
务必将其标示为@Transient,否则ORM框架默认其注解为@Basic
实例:
hibernate.properties配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> < hibernate-configuration > < session-factory > < property name = "hibernate.dialect" >org.hibernate.dialect.MySQLDialect</ property > <!-- <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql:///hibernate_struts_stumanager</property> --> < property name = "hibernate.connection.driver_class" >com.mysql.jdbc.Driver</ property > < property name = "hibernate.connection.url" >jdbc:mysql://localhost:3306/mypage</ property > < property name = "hibernate.connection.username" >root</ property > < property name = "hibernate.connection.password" >root</ property > < property name = "hibernate.show_sql" >false</ property > < property name = "hibernate.hbm2ddl.auto" >create</ property > <!-- <property name="hibernate_current_session_context_class">thread</property> --> < property name = "current_session_context_class" >thread</ property > < mapping class = "com.entity.Students" /> </ session-factory > </ hibernate-configuration > |
实体类Student:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
package com.entity; import java.io.Serializable; import java.util.Date; import javax.persistence.Column; import javax.persistence.Embedded; import javax.persistence.EmbeddedId; import javax.persistence.Entity; //JPA注解 import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.Table; import javax.persistence.Transient; import org.hibernate.annotations.GenericGenerator; /* * 学生实体类 */ //@Entity// //@Entity(name="t_students")//如果不添加名字,则默认与实体类名字相同,如果想要自行设置表明,就需要自己进行添加 @Entity @Table (name= "t_students1" ,schema= "mypage" ) public class Students implements Serializable{ @Id // @GeneratedValue // @GeneratedValue(strategy=GenerationType.AUTO)//与@GeneratedValue结果相同,字符串类型不能指定为AUTO类型 // private int sid; //学号 // @GeneratedValue(generator="sid") // @GenericGenerator(name="sid",strategy="assigned") // @Column(length=11) // private String sid; @EmbeddedId private StudentPK pk; // @Id // // @Column(length=11) private String sname; //姓名 private String gender; //性别 private Date birthday; //出生日期 private String major; //专业 private Address add; @Transient //表示该字段不会被ORM映射到表里的字段 private double salary; //薪水 public Students(){ } public Students(StudentPK pk, String sname, String gender, Date date, String major,Address add, double salary) { // super(); this .pk = pk; this .sname = sname; this .gender = gender; this .birthday = date; this .major = major; this .add = add; this .salary = salary; } public StudentPK getPk() { return pk; } public void setPk(StudentPK pk) { this .pk = pk; } public String getSname() { return sname; } public void setSname(String sname) { this .sname = sname; } public String getGender() { return gender; } public void setGender(String gender) { this .gender = gender; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this .birthday = birthday; } public String getMajor() { return major; } public void setMajor(String major) { this .major = major; } public Address getAdd() { return add; } public void setAdd(Address add) { this .add = add; } public double getSalary() { return salary; } public void setSalary( double salary) { this .salary = salary; } } |
StudentPK实体类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
package com.entity; import java.io.Serializable; import javax.persistence.Column; import javax.persistence.Embeddable; @Embeddable public class StudentPK implements Serializable{ /** * */ private static final long serialVersionUID = 1L; @Column (length= 18 ) private String id; //身份证号 @Column (length= 8 ) private String sid; //学号 public StudentPK(){ } public StudentPK(String id, String sid) { this .id = id; this .sid = sid; } public String getId() { return id; } public void setId(String id) { this .id = id; } public String getSid() { return sid; } public void setSid(String sid) { this .sid = sid; } @Override public boolean equals(Object obj) { // TODO Auto-generated method stub return super .equals(obj); } @Override public int hashCode() { // TODO Auto-generated method stub return super .hashCode(); } } |
地址类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
package com.entity; import javax.persistence.Embeddable; import javax.persistence.Embedded; // 地址类 @Embeddable //表示是一个嵌入类,这个类的对象在另一个实体类中充当属性 public class Address { private String postCode; //邮编 private String address; //地址 private String phone; //联系电话 public Address(){ } public Address(String postCode, String address, String phone) { this .postCode = postCode; this .address = address; this .phone = phone; } public String getPostCode() { return postCode; } public void setPostCode(String postCode) { this .postCode = postCode; } @Embedded public String getAddress() { return address; } public void setAddress(String address) { this .address = address; } public String getPhone() { return phone; } public void setPhone(String phone) { this .phone = phone; } } |
测试类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
package com.entity; import java.util.Date; import java.util.EnumSet; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.Test; public class TestStudents { @Test public void testShemaExport(){ //创建hibernate配置对象 Configuration config = new Configuration().configure(); //创建服务注册对象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); SchemaExport export = new SchemaExport(config); export.create( true , true ); } @Test public void addStudents(){ //创建hibernate配置对象 Configuration config = new Configuration().configure(); //创建服务注册对象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); //创建会话 Session session = sessionFactory.getCurrentSession(); //创建事务 Transaction tx = session.beginTransaction(); Address add = new Address( "700005" , "河南理工大学" , "15039117115" ); StudentPK pk = new StudentPK( "012345678912345678" , "55555555" ); Students s = new Students(pk, "张三丰" , "男" , new Date(), "太极拳" ,add, 7899 ); session.save(s); tx.commit(); // SchemaExport export = new SchemaExport(config); // export.create(true,true); } } |
总结
以上就是本文关于hibernate属性级别注解实例代码的全部内容,希望对大家有所帮助。在此也非常希望大家对本站多多支持。
原文链接:http://blog.csdn.net/wojiaohuangyu/article/details/51768672