hibernate-注解及配置
联合主键:
一、将联合主键的字段单独放在一个类中,该类需要实现java.io.Serializable接口并重写equals和hascode,再将该类注解为@Embeddable,最后在主类中(该类不包含联合主键类中的字段)保存该联合主键类的一个引用,并生成set和get方法,并将该引用注解为@Id
二、将联合主键的字段单独放在一个类中,该类需要实现java.io.Serializable接口并重写equals和hascode,最后在主类中(该类不包含联合主键类中的字段)保存该联合主键类的一个引用,并生成set和get方法,并将该引用注解为@EmbeddedId
三、将联合主键的字段单独放在一个类中,该类需要实现java.io.Serializable接口并要重写equals和hashcode.最后在主类中(该类包含联合主键类中的字段)将联合主键字段都注解为@Id,并在该类上方将上这样的注解:@IdClass(联合主键类.class)
/**
* 判断传入的参数是否是自己需要的参数
*/
@Override
public boolean equals(Object obj) {
if(obj == null || !(obj instanceof PkUserLog)){
return false;
}
PkUserLog pk = (PkUserLog) obj;
if(pk.orgPrefix.equals(this.orgPrefix) && pk.synchronizationDate.equals(this.synchronizationDate)){
return true;
}else{
return false;
}
}
/**
* hash值唯一化
*/
@Override
public int hashCode() {
int result1 = this.orgPrefix == null ? 0 : this.orgPrefix.hashCode();
int result2 = this.synchronizationDate == null ? 0 :this.synchronizationDate.hashCode();
return result1+result2;
}
主键生成策略:自定义主键
@GeneratedValue(strategy = GenerationType.IDENTITY,generator="paymentableGenerator")
@GenericGenerator(name = "paymentableGenerator", strategy = "assigned")
主键生成策略:sequence
/** 主键 **/
@SequenceGenerator(name="userIdPk",allocationSize=1,initialValue=1,schema="apps",sequenceName="user_s")
@Id
@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="userIdPk")
如果不指定sequence名,则会调用hibernate内置sequence,会在DB中建立一个hibernate_sequence。
如果不设置initialValue=1会出现序号从某个负值开始。initialValue表示从几开始,allocationSzie表示跨度,尽管在数据库建立sequence时已经设置但还是会出现负值。因此添加此设置。@SequenceGenerator也可设置在类上面。
对象类设置:
@Entity //实体类
@Table(name="mhr_suggestion") //表名
@Column(name="create_date") //列名
@DateTimeFormat(pattern="yyyy-mm-dd hh:mi:ss") //日期格式Json转化
@Transient // 非数据库字段
@OrderBy(value="DESC") //排序
@OneToMany
一个表中的某个字段是另一个表的主要外键,因此可以做两个表的关联设置。不一定要设置外键。如果设置有外键可不设置JoinColumn或mapped。
@OneToMany(targetEntity=FlexValueDO.class,fetch=FetchType.EAGER,mappedBy="User[当子表存在@ManyToOne双向关联时,可采用此方式]")
@JoinColumn(name="data_id[从表的关联columnName]",nullable=true,updatable=true,insertable=true,referredBy="user_id[主表与之关联的columnID,如果不设置默认用主键]",)
@OrderBy("createDate[对象列名] ASC")list结果排序
private List<FlexValueDO> valueList = new ArrayList<FlexValueDO>();
oneToMany有5个属性:
fetch - 配置加载方式。default LAZY,取值有
Fetch.EAGER - 及时加载,多对一默认是Fetch.EAGER ,如果遇到session关闭,将懒加载换成立即加载。
Fetch.LAZY - 延迟加载,一对多默认是Fetch.LAZY
cascade - 设置级联方式,default {},取值有:
CascadeType.PERSIST - 保存
CascadeType.REMOVE - 删除
CascadeType.MERGE - 修改
CascadeType.REFRESH - 刷新
CascadeType.ALL - 全部
targetEntity --设置对应的对象
targetEntity=FlexValueDO.class
mappedBy -- 当双向关联(bidirectional)时,指向子类的父类对象名。default '',
注意:mappedBy和JoinColumn不能重用。
orphanRemoval -- default false,删除孤立外键对象,即外键关联的对象不存在时,将空关联的对象删除。
@NamedQueries 和 @NamedQuery
用于提前将sql写好,在使用时直接使用,根据name即可获取。
@NamedQueries:多个nameQuery时,使用这个进行包装。
@Entity
@Table(name="re_items")
@NamedQueries({
@NamedQuery(name="findByCode",query=" from ReItemsDO where itemCode=:itemCode"),
@NamedQuery(name="findByType",query=" from ReItemsDO where itemType=:itemType")
})
@SequenceGenerator(allocationSize=1,initialValue=1000,name="reItemsS",sequenceName="re_items_s")
public class ReItemsDO implements Serializable {
在使用时,直接调用即可:
this.findByNamedParam("findByCode", "itemCode", "34555");
hibernate-注解及配置的更多相关文章
- Hibernate 注解方式配置
在Hibernate3之后就可以使用注解的方式去配置.而且在工作中我们使用的更多的也是注解方式去配置项目,所以还有一部分使用配置文件去配置的一些关系就不在此去一一举例,需要了解的朋友可以去查看Hibe ...
- Hibernate注解方式配置-继承关系
在JPA中,实体继承关系的映射策略共有三种:单表继承策略(table per class).Joined策略(table per subclass)和Table_PER_Class策略. 1.单表继承 ...
- Hibernate注解配置
在之前的第一次对框架的实际应用中,我使用的是Hibernate的xml配置方法,xml配置方法非常繁琐, 还是推荐所有使用Hibernate的人使用注解方式进行配置,在这篇文章中,我将列举出我们常用的 ...
- 。。。Hibernate注解配置的注意事项。。。
今天本来打算录视频的,突然遇到一个拦路虎,Hibernate注解配置,有一个注意点:要么都在属性上面注解配置,要么都在getXX()方法上面用注解配置,要不然就会报错: Caused by: org. ...
- Hibernate 注解时 hibernate.hbm.xml的配置方法 以及与SSH整合里的配置方式
①纯Hibernate开发: 当你在Bean中写入注解后,需要告诉hibernate哪些类使用了注解. 方法是在hibernate.hbm.xml文件中配置 <!DOCTYPE hibernat ...
- hibernate注解配置举例说明
Hibernate Annotation (Hibernate 注解) 进入:http://www.hibernate.org 说明文档: 英文:http://docs.jboss.org/h ...
- Hibernate注解使用以及Spring整合
Hibernate注解使用以及Spring整合 原文转自:http://wanqiufeng.blog.51cto.com/409430/484739 (1) 简介: 在过去几年里,Hibernate ...
- 【maven + hibernate(注解) +spring +springMVC】 使用maven搭建项目
研究,百度,查资料+好友帮助,使用MyEcplise2015工具,通过maven搭建hibernate+springMVC+spring的项目,数据库采用MySql5.5 不过使用的版本会在项目搭建过 ...
- Hibernate注解映射sequence时出现无序增长问题+hibernate 映射 oracle ID自动增长:
Hibernate注解映射sequence时出现无序增长问题+hibernate 映射 oracle ID自动增长: 通过Hibernate注解的方式映射oracel数据库的sequence主键生成器 ...
- Hibernate 注解 没有加@Column一样会在数据库创建这些字段
Hibernate 注解 没有加@Column一样会在数据库创建这些字段 如下一个注解类: package com.hyy.hibernate.one_to_many.domain; import j ...
随机推荐
- GridView实现数据编辑和删除
<asp:GridView ID="gv_Emplogin" runat="server" AutoGenerateColumns="False ...
- mysql 严格模式 Strict Mode说明
1.开启与关闭Strict Mode方法 找到mysql安装文件夹下的my.cnf(windows系统则是my.ini)文件 在sql_mode中增加STRICT_TRANS_TABLES则表示开启严 ...
- RAC4——架构和变化
1.RAC的架构 2.由单实例变RAC的变化 1.SGA的变化: 和传统的单实例相比,RAC 实例中SGA最显著的变化时多了一个GRD(Global resource directory)部分. ...
- LOJ 2542 「PKUWC2018」随机游走 ——树上高斯消元(期望DP)+最值反演+fmt
题目:https://loj.ac/problem/2542 可以最值反演.注意 min 不是独立地算从根走到每个点的最小值,在点集里取 min ,而是整体来看,“从根开始走到点集中的任意一个点就停下 ...
- Android 禁止系统进入深度休眠
在Linux系统中,wake_lock是一直锁机制,只要有驱动占用这个锁,系统就不会进入深度休眠. 获取此锁的方法有两种: 1.在adb中通过指令获取wake_lock,系统就不会进入深度休眠 ech ...
- dede的织梦问答模块也可以支持arclist标签
dedecms织梦问答等模块支持arclist标签,实现随机调用其他栏目文章 就是让模块模板文件支持调用主站的模板,因为调用主站下的/templets/default/模板,也就实现了支持调用所有标签 ...
- java 解析office文件 大全
原文地址:http://ansjsun.iteye.com/blog/791142 读取OFFICE文件纯文本 package org.css.resource.businesssoft.search ...
- python使用分治法找序列最大值
最近上算法导论课,说道分治法,回来想用python写写程序练练手,于是模仿一通写了如下的代码: __author__ = 'day' def ArrayMaxMin(Array): return ma ...
- JavaScript之图片操作3
在页面布局中,常常会用到九宫格布局,如下图所示: 本次我们就以九宫格为基础进行图片的布局操作,首先我们以上面的图片的为例,假设每个格子的大小都相同,将每一个格子相对其父元素进行定位,这样,我们只需要控 ...
- ORACLE中index的rebuild(转)
Oracle里大量删除记录后,表和索引里占用的数据块空间并没有释放. table move可以释放已删除记录表占用的数据块空间,整理碎片.如果将表格用move方式整理碎片后,索引将失效,这时需要将索引 ...