1.Hibernate引用jar文件,建立hibernate.cfg.xml,并配置好改文件.
2.方言:<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
3.使用xml建立Hello world!
(1)xml配置映射实体类:(Class.hbm.xml)
<class name="Class">
<id name="id"></id> <!--主键-->
<property name="age"></property> <!--属性-->
</class>
(2)在hibernate.cfg.xml中配置:<mapping resource="cn/bywei/model/Class.hbm.xml"/>
(3)使用Session
Configuration cfg=new Configuration();
SessionFactory cf=cfg.configure().buildSessionFactory();
Session session=sf.openSession();
session.beginTransaction();
session.save(model);
session.getTransaction().commit();
session.close();
sf.close();
4.使用Annotation建立HelloWorld!
jpa:javax.persistence.Entity;(JPA是一套非常好的标准)
(1)建立一个Model类,使用注解 @Entity标识实体类 @Id 标识主键 @GenertedValue 标识自动增长列
(2)在hibernate.cfg.xml中配置:<mapping resource="cn.bywei.model.Class"/>
(3)使用Session:
Configuration cfg=new AnnotationConfiguration();
SessionFactory sf=cfg.configure().buildSessionFactory();
Session session=sf.openSession();
session.beginTransaction();
session.save(Model);
session.getTransaction().commit();
session.close();
sf.close();
---------小技巧----------
1.使用注解@提示:设置 content Assist
-------------------------
5.O/R Mapping 面对对象的操作
Hibernate.cfg.xml基础配置
1.<property name="hbm2ddl.auto" >create/update/create-drop/validate</property>自动创建表
2.显示sql语句<property name="show_sql">true</property>
3.格式化sql语句<property name="format_sql">true</property>
---------小技巧----------
1.搭建日志环境slfj logfj
2.搭建测试环境 @Test 标识测试方法 @BeforeClass执行前调用的方法@AfterClass
-------------------------
4.Annotation:在Model中指定实体类所对应的数据库Table:@Table(name="tableName")
Xml:<class name="table" table="".......
5.字段名和属性名不同时:Annotation:@Column(name="columnName")
6.指定不可存储到数据库中的属性:Aannotation:@Transient
7.格式化日期精度 @Temporal(TemporalType.DATE) 可以把日期或者日期和时间存储到数据库中
8.映射枚举类型:
public enum Title{
A,B,C
}
private Title title;
@Enumerated(EnumType,STRING) //枚举
public Title getTitle(){
******
}
9.ID的生成策略
xml:<id name="id">
<generator class="uuid"></generator> //class=uuid 标识 字符 native 设置(sqlserver)自动增长列,squence (Oracle中标识列),auto_increamt(mysql)
</id>
Annotation:@generatedValue auto(相当于xml中的active)
当不使用Oracle时,可以设置@GeneratedValue(startegy=GenerationType.IDENTITY) 设置id的生成策略(sqlerver,mysql)
@sequenceGenerator(name="标识名字",sequenceName="数据库中的sequence名字") 指定Oracle生成的sequence名字
@TableGenerator 生成主键策略
@TableGenerator(
name="",
table="GENERATOR_TABLE",
pkColumnName="key",
valueColumnNamne="",
pkClumnValue="",
allocationSize=1
)
10.联合主键(id,name)作为联合主键
在类中:
public class pk implements Serializable{
private int id;
private String name;
}
//@Override equals 和hashcode
//关系到虚拟内存所以需要序列化
//为了判断id 和name和传递过来的是相等的,所以需要@Override equals
public class lianhe{
private pk pk;
}
(1)xml中配置:
<composite-id name="pk" class="****">
<key-property name=""/>
<key-property name=""/>
</composite-id>
(2)Annotation的配置:
-把主键类(pk)注解为@Embeddable,并且把主键的属性注解为@Id
-把主键的属性注解为@EmbeddedId 表示嵌入的主键id
-直接在Entity上注解@IdClass(PK.class) 并在主键id,name上注解@Id
核心开发接口
1.读取配置:
SessionFactory sf=new AnnotationConfiguration().configure("hibernate.cfg.xml").buildSessionFactory();
Session session=sf.getCurrentSession(); //从上下文(在配置文件中设置current_session_context_class--取值:jta,thread,managed,custom.Class)查找,如果有就获取Session,没有就创建新的Session.
//-用于事务的边界 -事务提交时自动Close
//Session session=sf.openSession();//永远是创建一个新Session
session.beginTransaction();
session.save(Entity);
session.getTransaction().commit();
2.对象的三种状态
(1)Transient 刚刚new出来,内存中有对象,但无id
(2)Persistent 内存中有id,在于Session中,数据库中也存在id
(3)Detached Session已经Close没有了Id,数据库中存在id
3.Hibernate的CRUD
(1)save() 对象的三种状态
(2)delete()
(3)load() 和 get()
-load() 生成一个对象代理,需要用到的时候才会调用,
-get() 直接读取数据
(4)update() //设置部分字段不更新@Column(updatable=false)
(5)saveOrUpdate()
(6)clear() 清除Session
(7)flush() 让缓存与数据同步 session.setFlushMode(FlushMode.COMMIT)设置flush的同步时间
4.自动建表
(1)使用hibernate.cfg.xml中的配置自动建表
(2)使用程序控制:new SchemaExport(new AnnotationConfiguration().configure()).create(显示sql-true/false,是否执行到数据库-true/false);
关系映射:
1.一对一
a)单向 一对一单向外键关联:在一方设置另一方的引用(数据库表中设置为外键关联)
Annotation: 在引用上注解:@OneToOne @JoinColumn(name="pk_id")设置引用的外键id名称
xml:<many-to-one name="" column="" unique="true"/>
一对一单向主键关联:
Annotation:在引用上设置@PramaryKeyJoinColumn(hibernate3.2好像有点小bug)
xml:****
b)双向 一对一双向外键关联:在两方都有对方的引用,双方都设置:@OneToOne,其中一方还需设置@OneToOne(mappedBy="另一方的引用名称")
一对一双向主键关联:@OneToOne @PrimaryKeyJoinColumn
xml:****
c)联合主键:@JoinColumns
d)组件映射:在数据库中配置为一张表,把一方设置为另一方的一部分,在引用上设置:@Embedded (表示作为这张表的一部分嵌入到)
2.一对多 多对一
a)多对一的单向:
Annotation:多指向一(@ManyToOne)
xml:<many-to-one name="属性名" column="生成的外键关系名"/>
b)多对一的双向:
Annotation:在多指向一设置@ManyToOne,在一指向多设置@OneToMany(mappedBy="多的一方的关系名称")
xml:一<one-to-many class="" column="和多的一致"/> 多<many-to-one name="" column="和一的一致"/>
3.多对多
a)多对多的单向关联
private Set<**> **=new HashSet<**>();//设置对方的引用
Annotation:一方@ManyToMany @JoinTable(name="中间表名",joinColumns={@JoinColumn(name="对应自己的表的关系名称")}inverseJoinColumns={,@JoinColumn(name="另外一张表的关系名称")})
xml:一方
<set name="属性名" table="数据库中间表名" >
<key column="指向自己的表的关系名"/>
<many-to-many class="" column="指向另外一张表的关系名"/>
</set>
b)多对多的双向关联
private Set<**> **=new HashSet<**>();
//做好单向关联后
Annotation:使用注解@ManyToMany(mapedBy="另外一类(多)中的引用名称")
xml:在另一方设置<many-to-many class="" column=""/>
4.关联关系中的CRUD
(1)保存时注意关联
使用Annotation设置级联操作:在指向另一类的@关系上设置(cascade={casadeType.ALL})//表示对所有的CRUD都进行级联操作
在双向关系中需要设置好双向关联
(2)加载数据 fetch主要影响get/load
(cascade={casadeType.ALL},fetch=FetchType.EAGER) //FetchType取值(EAGER,LAZY)
(3)更新数据时 先做load,再设值
(4)删除数据时 注意casade的设置问题,建议使EJB QL,HQL
5.集合映射(了解)
Set 参考多对多关系映射中(常用)
List 雷同Set(指定排序时@OrderBy("默认Id 或者 属性 asc/desc"))
Map 在设置Set的基础上设置@MapKey(name="map中使用哪个字段作为key")
//里面不能装载基础类型
6.继承映射(了解)
(1)设计为一张表(父类和子类放在一张表中,使用一个标识列标识是哪个对象(type))
(2)设计为多张表(父类一张,子类设计为分表)
(3)设计一张共有的属性,子类保存特有属性
//实现方式可以查找
7.树状映射(重要)
实体类设计:(parent表示父项)
id,name,Set<parent>,parent
在parent上@ManyToOne @JoinColumn(name="parent_id")
在Set上@OneToMany(mappedBy="parent")
--树状结构的打印
查询语言: NativeSQL(本地的sql语言)>HQL(hibernate query language)>EJB QL(JP QL 1.0)>QBC(Query By Cretira)>QBE(Query By Example)
HQL和EJB QL
session.createQuery("查询语句");
注明:category
1.from 类名
2.select distinct from 类名
3.from 类名 where id >:min and id<max
Query.setInteger("min",2);
Query.setInteger("max",2);
Query.setParameter("max",3);
Query.setMaxResults(4); //最大结果集
Query.setFirstResult(1); //读取的起点
Query.uniqueResult();
4.导航
from topic t where t.category.id=1
join // 联合查询
select t.tilte,c.name from topic t join t.category c
is not null //不为空
is empty //为空
like '%_' //模糊查询
5.函数
lower()
upper()
trim()
concat()
length()
(不常用)
abs()
sqrt()
mod()
6.current_date 当前日期 current_time 当前时间 current_timestamp 当前日期和时间
7.查询
count()
group by
having
avg()
all()
exists() / not exists() //能用这个时就用这个
in() / not in()
8.session.getNameQuery("");
9.NativeQuery
SQLQuery q=session.createSQLQuery("本地sql语句").addEntity(类名.class);
10.QBE
Criteria c=session.createCriteria(类名.class).add(Restrictions.约束属性);
Hibernate 性能优化
1.session.clear() 分页时需要注意使用,打开了链接需要关闭
内存泄露,java语法上没有,而当加载许多的session时就会出现内存泄露
3.1+N问题(当取一张关联了其他表的数据时,将会加载其他的数据引发许多的sql语句)
取关联对象的值,将引发获取被关联的对象的值,这就是1+N问题
(1)@ManyToOne(fetch=FetchType.Lazy) //其他的被关联的对象语句将会在需要时发出
(2)@BatchSize(size=5) //只取五条数据,注解添加到被关联的对象上面
(3)join fetch: session.createQuery("from Topic t left join fetch t.category c");
//使用了外连接,只发一条sql语句
4.list和iterator的区别
(1)iterator 先取id再取对象,重复使用时,先查找缓存,再查找数据库.
(2)list 获取所有,不会查找seesion,但会先保存到session中去
5.二级缓存和查询缓存(查询的是一样的数据)
一级缓存:session级别的缓存
二级缓存:sessionFactory级别的缓存
load默认使用二级缓存,iterator默认使用二级缓存
list默认往二级缓存加数据,但查询时不先查询二级缓存
二级缓存需要在配置文件中打开
缓存算法: lru,lfu,fifo
6.事务并发处理
a)acid
b)事务的隔离级别
分享到:
相关推荐
传智播客 hibernate 完全学习文档,没有更好
学习 Hibernate,理解并掌握这些核心概念,对于构建高效、可扩展的 Java 应用程序至关重要。同时,了解如何配置和管理二级缓存,以及如何根据不同的数据库环境选择合适的主键生成策略,也是提高应用程序性能的关键。
《Hibernate完全参考手册》是Java开发领域中关于Hibernate框架的重要学习资源,主要涵盖了该框架的全方位知识。Hibernate是一个开源的对象关系映射(ORM)框架,它简化了Java应用程序与数据库之间的交互,使得开发者...
Hibernate中文参考文档是一份面向中文用户的Hibernate学习资源,它覆盖了Hibernate的各个方面,包括但不限于核心概念、配置方法、会话管理、事务处理、查询语言、缓存机制和性能优化等。这份文档因其内容全面而受到...
通过这份中文参考文档,开发者可以深入理解Hibernate的核心概念,学习如何设计和实现数据持久化层,从而提升Java应用的开发效率和数据库操作的灵活性。无论你是初学者还是经验丰富的开发者,这份文档都是不可多得的...
《Hibernate 3.2 官方中文完全参考手册》是一份详尽的文档,旨在为开发者提供关于Hibernate框架全面深入的理解和使用指南。Hibernate是一种Java持久化解决方案,它通过对象关系映射(ORM)技术,将Java应用中的对象...
有java api中英文版,Ajax_XMLHttpRequest帮助文档,Apache+Ant+1.7,Comm2.0_参考手册,DHTML_网页制作完全手册_中文,DHTML文档对象模型中文手册,DOS_练就高手,Hibernate3.1.2_帮助文档_中文,Hibernate3.2_帮助...
学习相关的学习资源,如官方文档、教程、示例代码,以及社区论坛,这些都能帮助深入理解和解决问题。 ### 第 5 课 环境准备 确保正确安装并配置JDK、Hibernate库,以及合适的数据库驱动。设置相应的环境变量和项目...
文档还提供了关于如何获取Hibernate,包括下载Hibernate模块/工件、下载发布包和从Maven仓库获取艺术工件的信息。这对于初学者来说是一个很好的开始,因为它涵盖了设置Hibernate环境所需的所有基本步骤。 总而言之...
`Hibernate中文参考文档 V3.2.chm`是对Hibernate框架的深入解释,`CSS中文完全参考手册.chm`是CSS的全面指南,而`html语法教程.chm`则专注于HTML的学习。通过学习这些文档,开发者可以深入理解并掌握这些技术,从而...
通过上述知识点的学习,我们不仅能够更好地理解Hibernate的工作原理,还能够在实际项目中更加合理地设计数据库结构和事务处理逻辑,从而提高系统的稳定性和性能。接下来,我们将深入探讨Hibernate的核心概念和技术...
不过,通常这样的压缩包可能包含了示例配置文件、源代码和相关的文档,帮助开发者了解和学习如何在自己的项目中配置和使用hibernate-aop。实际操作时,需要根据提供的示例逐步配置,并结合自己的项目需求进行调整。 ...
在这个“hibernate5.3.3”压缩包中,包含的是Hibernate 5.3.3版本的源码、文档以及可能的构建工具,适合用于学习和开发。SSH框架整合指的是Spring、Struts和Hibernate这三大开源框架的集成,它们共同构成了Java企业...
标题和描述均提到了“Hibernate学习笔记”,暗示了本文档主要关注的是Hibernate这一持久化框架的学习要点。以下是对文档中提及的关键知识点的深入探讨: ### 对象持久化的理论 对象持久化是指将内存中的对象状态...
Hibernate的主要目标是为开发者提供一个无缝的持久层解决方案,使得开发者可以完全专注于业务逻辑而不必关心数据库交互的细节。 **Hibernate特点:** 1. **自动化的ORM映射**:Hibernate能够自动将Java对象映射到...
10. **Hibernate 中文api文档下载 .chm**:这个文档可能是Hibernate API的中文版,对于中文学习者来说,更便于理解和查阅。 通过这些文档,你可以系统地学习Java开发,包括后端的Spring、Struts和Hibernate,前端的...
### MyEclipse Hibernate Quickstart详解 #### 序言 本文档是使用 Sun JDK 1.4.2、Eclipse 3.1 和 MyEclipse 4.0 编写的。...对于更高级的功能和应用场景,建议深入学习 Hibernate 的官方文档和其他相关资源。
### 关于ibatis学习文档的关键知识点 #### 一、ibatis简介 - **定义**:ibatis是一个开源的持久层框架,它简化了Java应用程序与数据库之间的交互过程,但相较于Hibernate等其他ORM(对象关系映射)框架,ibatis更...
Hibernate 4.0.chm文档是学习和掌握这一版本的关键,它提供了关于配置、实体管理、查询语言(HQL)及事务处理等全面的指南。 Hibernate Annotation是Hibernate的一部分,它允许开发者使用注解来定义对象关系映射,...
10. **hibernate_1**:这个文件名可能是指一系列关于Hibernate学习的资源,可能包括其他示例代码、文档或教程。为了深入学习,你可以查看这个文件中的内容。 总之,搭建Hibernate环境是Java开发中的基础工作,理解...