Hibernate注解配置
在之前的第一次对框架的实际应用中,我使用的是Hibernate的xml配置方法,xml配置方法非常繁琐, 还是推荐所有使用Hibernate的人使用注解方式进行配置,在这篇文章中,我将列举出我们常用的注解配置,下面我将分为下面点进行阐述。
一、类级别注解
二、属性级别注解
三、关联映射关系
一、类级别注解
A)@Entity
@Entity:映射实体类型
@Entity(name=””):指定在数据库中与其对应的表名
在使用@Entity时必须存在主键。
B) @Table(name=””, catalog=””, schema=””)
与@Entity配合使用,name属性代表在数据库中与其对应的表名
Catalog 可选:表示Catalog名称 默认为””
Schema 可选:表示Schema名称 默认为””

C) @Embeddable
从面向对象的角度,表示该类可以被嵌入到其他类中。
从关系型数据库的角度,表示该类中标识的属性会映射成列之后嵌入到其他表中。
在正常的使用下,可以将该注解标识的属性嵌入到其他类中充当属性,但存在一种特殊情况,即该嵌入类充当主键的情况,将在@EmbeddedId进行说明。
二、属性级别注解
A) @Id:映射到数据库中充当主键,该注解可以同时标识多个属性,此时充当联合主键。
若作联合主键使用,该类必须实现serializable接口
String型属性作主键时,必须限定String长度,长度最长不要超过40位,否则会生成主键失败
B) @GeneratedValue(strategy=””, generator=””)
Strategy 可以有四种取值分别是:
GenerationType.AUTO:根据底层数据库自动选择
GenerationType.INDENTITY:根据数据库的Identity字段生成
GenerationType.SEQUENCE:使用Sequence在决定主键的取值
GenerationType.TABLE:使用指定的表决定主键的取值,结合 @TableGenerator使用
Example:
@Id
@TableGenerator(table=”tab_cat_gen”, allocationSize=1)
@GeneratedValue(Strategy=GenerationType.TABLE)
C) @Column
常用属性:
name : 与该属性对应的列的名称
nullable: 与该属性对应的列的值是否可以为null
uinique: 与该属性对应的列的值是否唯一
length:与该属性对应的列的域的长度上限
insertable: 表示在orm框架中插入一条记录时,该字段是否出现在insert语 句中。
updateable: 表示在orm框架中更新一条记录时,该字段是否出现在insert语 句中。
D) @Embedded 与 @EmbeddedId
被标识该注解的属性代表该属性的类是一个嵌入类,同时,该嵌入类必须带有 @Embeddable注解
当该属性被 标识为主键时,必须标识为@EmbeddedId,并且同时满足下面几个条件:
1实现Serializable接口
2有磨人的public的无参构造方法。
3实现equals() 和 HashCode() 方法。
E) @Transient:
该注解 该属性并不是一个映射倒数据库表的字段属性,ORM框架将会忽略该属性。
三、关系映射注解
A)单向一对一外键关联
设存在A、B双方存在一对一关系
@OneToOne(cascade=CascadeType.ALL)
@JoinColumn(name=””,unique=true)
其中A方标识上以上注解,name属性代表着与其对应的B方的列名
如果B方使用@Column重新指定了列名,该name应该指向修改过后的名字
B) 双向一对一外键关联
在a)的基础上,同时给B方加上以下注解
@OneToOne(mappedBy=””)
mappedBy指向A方的属性变量名
C) 单向多对一外键关联
设A方维护多的关系,B方维护一的关系
需要从A方到B方的多对一的单向关联关系
@ManyToOne(cascade={CascadeType.ALL}, fetch=FetchType.EAGER)
@JoinColumn(name="")
本质是需要在A方维护一个外键
只需要在A方配置以上注解,fetch属性代表对该属性的获取策略,作为多的一方, 需要积极(eager)地获取以节省资源。
@JoinColumn(name=””)中name属性代表要参照的列名,而非属性名。
D) 单向一对多外键关联
@OneToMany(cascade={CascadeType.ALL}, fetch=FetchType.LAZY)
@JoinColumn(name="")
一对多在数据库中的体现形式与多对一在数据库中的体现形式一样,都是需要在多的 一方中维护一个参照一的一方的一个外键,但是不同的是,我们需要通过配置注解, 使得我们可以使用一的一方的对象获取到一个(多的一方)的集合
作为一的一方,我们需要使用延迟加载技术(fetch=FetchType.LAZY),否则时 时刻刻都要对持有的集合进行维护,十分损耗服务器资源。
E) 双向一对多外键关联
双向一对多外键关联 = 单向一对多外键关联 + 单向多对一外键关联
只需要把这两种的配置迭加即可
F) 单向多对多外键关联
首先需要说明的是,我们在前面使用的几种关联关系中,我们都只要直接的使用双方 对应的两个表就足够我们完成对关系的维护。
但是在多对多的两种关系中,我们无法使用两个表,而是需要一个中间表来维护两个 表之间的多对多的关系
多对多的关系重点就是在指定中间表。
假设A、B双方存在多对多的关系:
只需要A、B中任意一方标识以下注解:
@ManyToMany
@JoinTable(
name="",
joinColumns={@JoinColumn(name="")},
inverseJoinColumns={@JoinColumn(name=""),
@JoinColumn(name=""),
@JoinColumn(name=""),
@JoinColumn(name="")}
)
@JoinTable用于标识中间表
name 表示表名
joinColumns 和inverseJoinColumn中可以指定对应的的外键列名,如果A、B 中存在联合主键,只需要指定多个@JoinColumn即可。
G) 双向多对多外键关联
双向多对多的外键关联只需要在单向的基础上,在B方加上一下注解(假设A方已经 维护好单向多对多关系):
@ManyToMany(mappedBy="")
mappedBy指向在A方中的变量属性名即可。
Hibernate注解配置的更多相关文章
- 。。。Hibernate注解配置的注意事项。。。
今天本来打算录视频的,突然遇到一个拦路虎,Hibernate注解配置,有一个注意点:要么都在属性上面注解配置,要么都在getXX()方法上面用注解配置,要不然就会报错: Caused by: org. ...
- Hibernate注解配置与XML配置区别
注解配置的方式与xml很很多类似: 首先是需要加入4个jar包:hibernate-commons-annotations.jar . hibernate-annotations.jar.ejb3-p ...
- hibernate注解配置举例说明
Hibernate Annotation (Hibernate 注解) 进入:http://www.hibernate.org 说明文档: 英文:http://docs.jboss.org/h ...
- hibernate 注解配置<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/X
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- 【maven + hibernate(注解) +spring +springMVC】 使用maven搭建项目
研究,百度,查资料+好友帮助,使用MyEcplise2015工具,通过maven搭建hibernate+springMVC+spring的项目,数据库采用MySql5.5 不过使用的版本会在项目搭建过 ...
- 用户、角色、权限三者多对多用hibernate的一对多注解配置
用户.角色.权限三者多对多用hibernate的一对多注解配置 //权限表@Table(name = "p")public class P { @Id @GeneratedValu ...
- Mingyang.net:注解配置Hibernate时报错Unknown Entity
注解配置时报错:org.hibernate.MappingException: Unknown entity: net.mingyang.cms.bean.User org.hibernate.Map ...
- Hibernate 注解时 hibernate.hbm.xml的配置方法 以及与SSH整合里的配置方式
①纯Hibernate开发: 当你在Bean中写入注解后,需要告诉hibernate哪些类使用了注解. 方法是在hibernate.hbm.xml文件中配置 <!DOCTYPE hibernat ...
- spring与hibernate整合配置基于Annotation注解方式管理实务
1.配置数据源 数据库连接基本信息存放到properties文件中,因此先加载properties文件 <!-- jdbc连接信息 --> <context:property-pla ...
随机推荐
- 可控制导航下拉方向的jQuery下拉菜单代码
效果:http://hovertree.com/texiao/nav/1/ 代码如下: <!DOCTYPE html> <html> <head> <meta ...
- 淡蓝风格的手机登录HTML模板
查看效果:http://hovertree.com/texiao/mobile/10/ 或者手机扫描二维码查看效果: 效果图: 代码如下: <!DOCTYPE html> <html ...
- mysql数据库权限及编码
CREATE DATABASE IF NOT EXISTS yourdbname DEFAULT CHARSET utf8 COLLATE utf8_general_ci; 在tigase中,发送消息 ...
- PHP中return 和 exit 、break和contiue 区别与用法
先说一下exit函数的用法. 作用: 输出一则消息并且终止当前脚本. 如果一段文本中包括多个以 结束的脚本,则exit退出当前所在脚本. 比如一篇php文本包括一下代码,则输出为world. < ...
- CRM(四川网脉系统)项目总结
CRM系统(四川网脉系统)项目总结 为期八天的四川网脉系统(CRM系统)项目结束了,不管是在做这个项目的过程中还是答辩的过程中都有一些收获,下面对整个项目的开发做一个大致的总结. 一.项目概况 四川网 ...
- ember.js里的实用方法
一款基于jQuery的插件,以下是关于数组的一些方法 var arr = ['Wang', 'Jason', '444128852@qq.com', 'i2cao.xyz', 'ubuntuvim.x ...
- CSS项目学习总结
1.我过去在HTML和CSS阶段是如何学习的? 我一开始学HTML和CSS,更多的是通过看视频.书籍,一个知识点一个知识点地去学习,很少把他们串联起来,看代码多于敲代码. 然而,通过现在这几个项目的实 ...
- MySQL错误(一)
Host 'localhost' is not allowed to connect to this MySQL server 手贱误操作将root用户删除,解决办法: 找到mysql的配置文件 my ...
- iOS 证书Bug The identity used to sign the executable is no longer valid 解决方案
现象:The identity used to sign the executable is no longer valid Please verify that your device’s cloc ...
- SharePoint 2013 使用JavaScript对象模型配置智能提示
前言 默认在VS2012/2013中编写SharePoint JavaScript 客户端对象模型,都没有智能感知的功能,用起来非常麻烦:其实,我们可以手动配置一下,让JavaScript可以进行智能 ...