Hibernate
Hibernate是一个开放源代码的对象关系映射框架
Hibernate的核心接口一共有6个,分别为:Session、SessionFactory、
Transaction、Query、Criteria和Configuration。
这6个核心接口在任何开发中都会用到。
通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制。
Session
Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句。)。
但需要注意的是Session对象是非线程安全的。同时,Hibernate的session不同于JSP应用中的HttpSession。这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSession对象称为用户session。
SessionFactory
SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。
这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。
Transaction
Transaction 接口是一个可选的API,可以选择不使用这个接口,取而代之的是Hibernate 的设计者自己写的底层事务处理代码。
Transaction 接口是对实际事务实现的一个抽象,这些实现包括JDBC的事务、JTA 中的UserTransaction、甚至可以是CORBA 事务。之所以这样设计是能让开发者能够使用一个统一事务的操作界面,使得自己的项目可以在不同的环境和容器之间方便地移植。
Query
Query接口让你方便地对数据库及持久对象进行查询,它可以有两种表达方式:HQL语言或本地数据库的SQL语句。
Query经常被用来绑定查询参数、限制查询记录数量,并最终执行查询操作。
Criteria
Criteria接口与Query接口非常类似,允许创建并执行面向对象的标准化查询。
值得注意的是Query接口也是轻量级的,它不能在Session之外使用。
Configuration
Configuration 接口的作用是对Hibernate 进行配置,以及对它进行启动。
在Hibernate 的启动过程中,Configuration 类的实例首先定位映射文档的位置,读取这些配置,然后创建一个SessionFactory对象。虽然Configuration 接口在整个Hibernate 项目中只扮演着一个很小的角色,但它是启动hibernate 时所遇到的每一个对象。
Hibernate大纲:
1.环境的搭建 xml annotation
2.Hibernate工作原理
3.常见的OR/M框架
4.基础配置
5.Id生成策略
6.核心开发接口介绍
7.对象的三种状态
8.关系映射
9.HQL
10.性能优化
1.环境的搭建
xml
<1>.加Hibernate 的jar文件
<2>.加JDBC驱动
<3>.建立相对应的数据库和表
<4>.创建hibernate.cfg.xml文件
<5>.创建Model类相对应的映射文件class.hbm.xml
<6>.将映射文件class.hbm.xml加入到hibernate.cfg.xml中
<7>.使用session工厂开始运行
annotation
<1>.加Hibernate 的jar文件,加入annotation所需要的包
<2>.加JDBC驱动
<3>.建立相对应的数据库和表(也可以通过文件自己创建)
<4>.创建hibernate.cfg.xml文件
<5>.在Model类中加入相应的注释,表明所对应的表和字段
<6>.将映射后的Model类加入到hibernate.cfg.xml中
<7>.使用session工厂开始运行
2.Hibernate工作原理
工作原理:工厂创建后,读取数据库链接文件,找到相应的类的映射文件,
解析类中的类名和DB中字段的相对关系,通过Hibernate自动拼成SQL语句并运行
hibernate工作原理:
3.常见的OR/M框架
TOPLINK , JDO , IBATIS JPA
4.基础配置
hibernate.cfg.xml 中的配置
hbm2ddl.auto (validate/update/create/create-drop)数据库中没有表,就自动创建表
show_sql 日志环境,显示出执行的sql
format_sql 格式化后的SQL进行输出
Xml
表名:table
字段名:column =""
不需要字段 :不写
自动生成:genertedVale="squence/native"
类型:type = ""
Annotation
表名:@Table(name="")
字段名: @Cloumn
不需要字段 :@Transient
自动生成:@GeneratedValue()
类型:@Temproal
5.Id生成策略
主键生成:
identity:mysql,sqk server ,db2
sequence:db2,PostgreSql,Oracle,
native:自动选择
6.核心开发接口介绍
Configuration
读取配置文件,通过bulidSessionFactory()创建一个sessionFactory对象
AnnotationConfiguration
Configuration
Session
1.管理一个数据的服务单元(事务单元)
2.执行CRUD操作
3.save() delete()
load(取数据才执行) 返回的是代理对象,等正真用到对象内容时发出SQL
get(不延迟) 直接从数据库加载
update()
局部提交,全局提交,
<1>updae
<2>改注释
<3>动态更新xml
<4>HQL
clear() 清除
SessionFactory
1.用来管理Session,维护数据库连接池
2.通常情况下每个单元只需要一个SessionFactory
3.除非要访问多个数据库的情况
4.关注俩个方法的区别:
openSession()<1>需要手动关闭,openSession每次都会拿新的链接
getCurrentSession()<2>拿原来的Session,会在上下文中找,会自动关闭,如果有旧的就用,没有就自己进行创建
Transaction
Query
Criteria
7.对象的三种状态
三种状态的区别:
1.有没有ID
2.ID在数据库中有没有
3.在内存中有没有(session缓存)缓存
三种状态:
Transient :内存中一个对象,没有ID,缓存中也没有
Persisent:内存中有,缓存中有,数据库有(ID)
Detached:内存中有,缓存中没有,数据库有(ID)
8.关系映射
关系映射:
一对一:实体是一对一的关系
单向:一个实体具有另一个实体的属性
双向:俩个实体都具有对方的实体的属性
Annotation: @OneToOne @joinColum @OneToOne(mappedBy="")
Xml <one-to-one property-ref=""> <many-to-one type="unique">
一对多:
单项关联
Annotation @onetomany @joincloum
Xml <one -to-many name="group" colum="tablename"><key>
多对一:
单项关联:
在多的那方加外键
Annotation 在单方用 @ManyToOne
Xml<many-to-one name="group" colum="tablename">
多对多:
组件映射:
9.HQL
本地SQL语言
EJBQL
createQuert("form classname where cloum > 100 order by cloum asc")
createQuert("select distinct classname from classname ")