您的位置:首页 > 其它

hibernate简介

2017-07-10 15:09 218 查看
什么是hibernate? 冬眠?

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,

它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,

使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 

为什么?

简化对数据库的操作.hibernate提供了不同数据库的统一接口,应用程序开发有了跨数据库的可能.

核心的API

configuration sessionfactoty session query transaction

工作原理

hibernate启动-->configuration(xml)-->sessionfactoty-->session

-->创建transaction-->持久化操作-->提交transaction-->关闭session

处理流程

请求-->session中查-->sessionfactoty-->DB



怎么使用?


步骤:

导包:hibernate核心包;数据库的驱动包

文件的配置:hibernate.cfg.xml(配置)/xxx.hbm.xml(映射)

调用hibernate的API对数据库进行操作

ID生成规则(重点)


自增类型(mysql和sqlserver)
create table student(id int not null auto_increment,name varchar(30),primary key(id))
insert into student(id,name) values(null,"Tom");
insert into student(name) values("Jack");
映射文件的<id><generator class="identity">


序列(oracle和db2)
<generator class="sequence">
<param name="sequence">seq_name</param>
</generator>


UUID
<generator class="uuid">

create table teacher(id varchar(100) primary key,name varchar(30))


hibernate对象生命周期管理(重点)

hibernate对象就是java中的实体对象.管理就是在实体对象的生命周期中被hibernate的操作.

临时状态:内存中有对象,DB中没有数据

持久状态:内存中有对象,DB中有数据,通过操作内存中的对象修改DB中的数据

游离状态:内存中有对象,DB中有数据,对象与数据断开了连接,修改对象不影响DB中的数据

HQL查询

hibernate Query Language

面向对象的查询语言,语法类似SQL,但与数据库无关

SQL:select 字段 from 表

HQL:select 属性 from 类

常用语法:

from 类; 不支持"select*"

select 属性 from 类

where

having

order by

group by

怎么使用?

获取session对象
编写HQL语句
创建查询对象Query
如果存在参数,调用setXXXX()赋值
调用Query的list()方法
关闭session对象
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: