`
jessen163
  • 浏览: 466667 次
  • 性别: Icon_minigender_1
  • 来自: 潘多拉
社区版块
存档分类
最新评论

HIbernate 知识点

阅读更多
Hibernate ORM(对象关系映射 O-R mapping)框架
对象 -持久化-数据库(关系型数据库)
对象 -关系
内存中的对象与数据库中字段的对应关系。
持久化标示---关系模型中的主键(用id来配)

Hibernate的三种对象状态:
1.transient:never persistent ,not associated with any Session 瞬时状态
2.persistent:associated with a unique Session  持久化状态
3.detached: previously persistent,nto associated with any Session 脱管状态

瞬时状态:内存中的对象在数据库中没有与之对应的记录,并且此对象也没有纳入Session的管理,那么此时对象的任何变化都不会发出SQL语句,也就是O和R没有联动。
(判断对象和数据库是否关联的重要标准就是判断对象是否具有持久化标示)

持久化状态:内存中的对象在数据库中有与之对应的记录,并且对象纳入Session管理,此时O的任何变化就会自动的发出SQL语句,也就是说对象和数据库是实时联动。

脱管状态:内存中的对象在数据库中有与之对应的记录,但是对象没有纳入Session管理,那么此时对象的任何变化都不会发出SQL语句,也就是O和R没有联动。


对对象设置了持久化标示,此时由于此标示在数据库中已经存在,则user变为托管状态,用 Update 自动的更新修改的数据。


//在get方法执行时,首先搜索缓存中是否存在持久化标示为1的对象,如果存在则直接从缓存中获取此对象,否则说明不存在,那么立即发送SQL进行查询,但是此处的缓存是Session级别的,出了本Session,持久化对象就失效了,我们称之为一级缓存。并不是每次修改都执行SQL update语句,它会自动查询改之前和改之后内存中的对象是否一致,不一致才执行update。(二级缓存:SessionFactory,所有服务器公用一个。)

pubic void testQuery(){
Session session=null;
try{
session=HibernateSessionFactory.getSession();
session.beginTransaction();
user=(User)session.get(User.class,1);//根据指定的标识符返回持久化对象,如果找不到返回//null,User.class:Class;1:Serializable(id)
System.out.println(user.getUsername()+":"+user.getPassword());
session.getTransaction().commit();
}catch(HibernateException e){
if(seession.getTransaction().isActive())
session.getTransaction.rollback();
e.printStackTrace();
}finally{
HibernateSessionFactory.closeSession(session);
}
}

------------------------
//load(class,id)方法:根据指定的标识符返回持久化对象。
代理模式(中介)
属于延迟加载,默认不发送SQL语句,只由当调用此对象的成员时才发送SQL语句。
如果要搜索的对象不存在,get报空指针异常,load报找不到对象异常。
----------------
//建议再删除之前先查询,删除完毕后user变成瞬时状态
删除:delete()
(1)user.setId(1);//1:已经存在,属于脱管状态
session.delete(user);//删除脱管对象对应的数据库记录删除
(2)user=session.get(User.class,2);//2:已经存在,user:持久化状态
session.delete(user);
user.setId(7);//变为脱管状态
user.setUsername("asdgadfghad");//
session.get(User.class,user.getId());//变为持久化状态

----------------------------------------
//user1脱管状态
user1.setId(12);
user1.setUsername("大明");
user1.setPassword("ddasdg");
//user2脱管状态
user2.setId(12);
user2.setUsername("二明");
user2.setPassword("asgas");
/*
这样会抛出异常
session.update(user1);
session.update(user2);
*/

session.merge(user1);//不改变状态,不会从脱管状态变为持久化状态
session.merge(user2);
-------------------------------------
Hibernate语句去创建表
Configuration cfg=new Configuration().configure();
SchemaExport se=new SchemaExport(cfg);
se.create(true,true);

-----------------------------
表和表的关系---对象和对象的关系
7种常见的关系:
单向
1-1:外键1-1 和 主键 1-1 
1-N
N-1
N-N
双向:
1-1
1-N(N-1)
N-N
(1)1-1
UserInfo--
Login--
(2)N-1
t_room:
id  room_name
user:
id  username roomId
-------------------------------------------------------
使用List:
<list name="students" table="t_teacher_student" cascade="save-update">
<key column column="t_id"></key>
<index column="stu_index"></index>
<many-to-many class="student" column="s_id"></many-to-many>
</list>
-------------------------------------------------------
继承映射(Inheritance Mappings)
(1)每个类分层结构一张表(table per class hierarchy)
(2)每个子类一张表(table per subclass)
(3)每个具体类一张表 (table per concrete class)
---------------
(1)每个类分层结构一张表
Person -->Student
       -->Worker
id name age sex  school factory type
1  aaa  22  男   清华            S
2  bbb  24  男           首钢    W
<discriminator>鉴别器
person.hbm.xml:
<hibernate-mapping package="vo">
<class name="Person" table ="t_person">
	<id name="id" column="id">
		<generator class="native"></generator>
	</id>
	<discriminator column="type" type="String"></discriminator>
	<property name="name" unique="true" not-null="true" column="name"/>
	<property name="age" column="age" length="32"/>
	<property name="sex" column="sex"/>
	<subclass name="Student" discriminator-value="STUDENT">
		<property name="school" column="school" length="60"/>
	</subclass>
	<subclass name="Worker" discriminator-value="WORKER">
		<property name="factory" column="factory"></property>
	</subclass>

</class>
</hibernate-mapping>

------------------------------
(2)每个子类一张表
t_person
id name age sex
t_student
id school pid
t_worker
id factory pid
--------
person.hbm.xml:
<hibernate-mapping package="vo">
<class name="Person" table ="t_person">
	<id name="id" column="id">
		<generator class="native"></generator>
	</id>	
	<property name="name" unique="true" not-null="true" column="name"/>
	<property name="age" column="age" length="32"/>
	<property name="sex" column="sex"/>

	<joined-subclass name="Student" table="t_student">
		<key column="id"></key>
		<property name="school" not-null="true"></property>
	</joined-subclass>
		
	<joined-subclass name="Worker" table="t_worker">
		<key column="id"></key>
		<property name="facotry" not-null="true"></property>
	</joined-subclass>

</class>
</hibernate-mapping>

---------------------
(3)每个具体类一张表
t_person

t_student
id name age sex school
t_worker
id name age sex factory
--------
person.hbm.xml:
<hibernate-mapping package="vo">
<class name="Person" table ="t_person" abstract="true">------t_person不会生成--------
	<id name="id" column="id" type="String">
		<generator class="uuid"></generator>
	</id>
	<property name="name" unique="true" not-null="true" column="name"/>
	<property name="age" column="age" length="32"/>
	<property name="sex" column="sex"/>

	<union-subclass name="Student" table="t_student">
		<property name="school" not-null="true"></property>
	</union-subclass>

	<union-subclass name="Worker" table="t_worker">
		<property name="factory" not-null="true"></property>		
	</union-subclass>

</class>
</hibernate-mapping>

------------------------------------------------
项目经验:
数据库的后台约束,尽量放到前台去验证,如:验证申请/修改的用户名是否数据库中已经存在,都在前台验证。
------------------------------------------------------------------------------------------------------
HQL(大小写敏感:类中的属性):
(1)select lastName,salary from Employee 
注意:lastName,salary :是对象的属性,而不知数据库表中的字段名。等价于(emp:别名):
select emp.lastName,emp.salary from Employee emp
(2)HQL支持对象导航:查询department.departmentName(department对象中有departmentName属性)
select emp.lastName,emp.salary,emp.department.departmentName from Employee  emp
hibernate会总动建立多表连接查询(where ....)
(3)内连:(与前面的语句等价)
select emp.lastName,emp.salary,dept.departmentName from Employee emp
inner join emp.department dept
(4)-----------where-------
select emp.lastName,dept.departmentName
from Employee emp,Department dept 
where emp.department.departmentId=dept.departmentId
(5)
左外连接:把左边那个表中不符合条件的数据查询出来
select emp.lastName,dept.departmentName
from Employee emp
left join emp.department dept

右外连接:把右边那个表中不符合条件的数据查询出来
select emp.lastName,dept.departmentName
from Employee emp
right join emp.department dept

内连接:发送等值连接条件
select emp.lastName,dept.departmentName
from Employee emp
join emp.department dept

with可以在join 后面设置条件,如:
select emp.lastName,dept.departmentName
from Employee emp
join emp.department dept
with dept.id=20
注意(返回一个对象,但需要重写构造器):
select new Employee(emp.lastName,dept.departmentName)
from Employee emp
join emp.department dept
(6)子查询
select e.lastName
from Employee e
where e.salary =
(
select max(emp.salary)              //,min(emp.salary),avg(emp.salary),sum(emp.salary) 
from Employee emp
)
(7)分组查询+条件(having)
select avg(emp.salary) emp.department.departmentId
from Employee emp
group by emp.department.departmentId
having avg(emp.salary)>=5000
(8)current_date() 当前日期:2009-06-11;current_time()当前时间:07:27:07
select emp.hireDate,current_date(),current_time() 
from Employee emp
(9)to_char和to_date
to_char:
select to_char(emp.hireDate,'YYYY MM DD')
from Employee emp
where to_char(emp.hireDate,'YYYY-MM-DD') between '1990-01-01' and '1998-01-23'
to_date:
select emp.hireDate
from Employee emp
where emp.hireDate between to_date('1990-01-01') and to_date('1998-01-23')
(10)order by 排序
select emp.lastName,emp.salary 
from Employee emp
order by emp.salary DESC

(11)ROWNUM 很重要
select aa.*,ROWNUM from
(
select last_name,salary,d.department_name
from employees e,departments d
where e.department_id=d.department_id
order by salary DESC
) aa
where RoWNUM<=5
------------主要用于分页
List list=session.createQuery("select emp.lastName,emp.salary 
from Employee emp
order by emp.salary DESC").setFirstResult(0).setMaxResults(5).list();

(12)自查询(工人和上司)
SQL语句:
select e.last_name,m.last_name
from emploees e,employees m
where e.manager_id=m.employee_id
HQL语句:
select emp.lastName,manager.lastName
from Employee emp
join emp.manager manager
(13)查询跟“King”在同一部门的员工个数
SQL语句:
select count(*)
from Employee e
where e.department_id=
(
select emp.department_id
from Employee emp
where emp.lastName='King'
)
HQL语句:
select distinct e.manager.employees.size
from Employee e
where e.lastName='King'

(14)HQL语句传参:
第一种:
List list=session.createQuery("
from Employee emp where emp.salary between ? and ?
").setParameter(0,5000.0).setParameter(1,10000.0).list();
第二种:
List list=session.createQuery("
from Employee emp where emp.salary between :sale1 and :sale2
").setParameter(sale1,5000.0).setParameter(sale2,10000.0).list();
(15)迭代器Iterator:
Iterator it=session.creaetQuery("from Employee").iterate();
while(it.hasNext()){
Employee emp = (Employee)it.next();
System.out.println(emp.getLastName()+"-"+emp.getSalary());
}
------------------------------------------------------------------------
一级缓存:Session级别(进程级别)
二级缓存:SessionFactory应用级别
--------------------------------------------------------------------------
Native SQL(原生SQL)
(1)单表查询
List<Employee> l=session.createSQLQuery("select (emp.*) from employees em").
addEntity("emp",Employee.class).list();
(2)多表查询
addEntity
addJoin
----------------------------------
处理大批量的更新/删除操作(不适合用hibernate操作),建议和数据库保持最短的联系:
Connnection conn=session.getConnection();
PreparedStatement ps=conn.prepareStatement("delete from employees");
-----------------------------------------
往HQL中传递数组参数:
Integer[] deptIds={50,60,90,10};
List<Department> list=session.createQuery("
from Department dept where dept.id in (:deptId)")
.setParameterList("deptId",deptIds)
.list();
--------------------------
get/load 都是应用一级缓存(session)
即,内存中有原来的对象,不会重发SQL语句。
-----------------------------
悲观锁  乐观锁  (表级锁)
----
ANSI92
数据库的隔离级别:
四种:

更新丢失:两个事务同时更新更新一条数据
不可重复读:
脏读:
幻读:读到了别人插入的数据
脏读     幻读        不可重复读
(1)未提交读      Y   Y Y
(2)提交读 N   Y Y
(3)可重复读 N   Y N
(4)序列化 N   N N
---------------------------------------
二级缓存(the second level cache)
hibernate.cfg.xml:
<property name="cache.use_second_level_cache">true</property>
<property name="cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
----------------------------------------
清空二级缓存中的Employee实体:
HibernateSessionFactory.getSessionFactory().evict(Employee.class);

-----------------------------------------------------------------------
//用户登录isLogin(User user)
private static final String ISLOGIN_HQL
="select count(*) from User user where user.username=? and user.password=?";
//判断此用户是否存在
private static final String QUERYUSERNAME_HQL
="select count(*) from User user where user.username=?";
-----------------------------
struct 与 hibernate 结合实例:
过滤器:
public void doFilter(ServletRequest request,ServletResponse response,
	FilterChain chain)throws IOException,ServletException{
Session session=null;
try{
	session=HibernateSessionFactory.getSession();
	session.beginTransaction();
	chain.doFilter(request,response);
	session.getTransaction().commit();	
}catch(HibernateException e){
	if(session.getTransaction().isActive()){
		session.getTransaction().roolback();
	}
	e.printStackTrace();
}finally{
	HibernateSessionFactory.closeSession();
}
}
DAO实现:如:
public boolean delete(String uid){//删除用户记录 
	boolean b=false;
	Session session=HIbernateSessionFactory.getSession();
	
	User user=(User)session.load(User.class,uid);
	b=session.delete(user);
	return b;
}


Hibernate 的加锁模式:
LockMode.NONE :有缓存用缓存,没缓存则从数据库读
LockMode.READ :直接从数据库读,不使用缓存数据
LockMode.WRITE :在insert update数据的时候,HIBERNATE内部使用的。
以上3种均为HIBERNATE级别的锁,也就是缓存级别的锁。


分享到:
评论

相关推荐

    Hibernate知识点总结

    ### Hibernate知识点总结 #### 一、Hibernate概述 Hibernate是一个开源的ORM(Object Relational Mapping,对象关系映射)框架,用于Java应用与关系型数据库之间的交互。它通过使用描述对象和数据库之间映射的元...

    hibernate知识点

    hibernate知识点的总结,适合初学者

    hibernate知识点汇总

    这篇文章主要汇总了关于 Hibernate 的一些关键知识点,对于准备面试的 IT 专业人士来说非常有用。 1. **持久化**:持久化是将应用程序的数据存储在数据库中,使得数据即使在应用程序关闭后也能长期存在。在 ...

    2023年hibernate知识点详解王成敏.doc

    Hibernate 知识点详解 Hibernate 是一个流行的 ORM(Object-Relational Mapping)框架,用于 Java 应用程序的持久层解决方案。下面是 Hibernate 知识点的详解: Hibernate 概述 Hibernate 是一个轻量级的 Java EE...

    hibernate知识点总结

    通过理解并熟练运用这些知识点,J2EE开发者能有效利用Hibernate简化数据库操作,提高开发效率,并更好地维护代码。学习Hibernate不仅有助于入门J2EE开发,也是进一步深入学习Spring Data JPA等高级技术的基础。

    hibernate主要知识点

    【hibernate主要知识点】 Hibernate 是一款流行的 Java 平台上的 ORM(对象关系映射)框架,它使得开发者可以使用面向对象的方式处理数据库操作,而无需直接编写 SQL 语句。ORM 框架如 Hibernate、TopLink 和 OJB ...

    Hibernate全部知识点

    Hibernate全部知识点

    Hibernate知识点总结(一).docx

    Hibernate 框架是Java开发中广泛使用的对象关系映射(ORM)工具,它简化了数据库操作,使得开发者可以通过对象模型来处理数据,无需编写大量的SQL语句。本篇文章将深入探讨Hibernate的核心概念和基本使用方法。 ...

    Hibernate知识点

    Hibernate的一些学习知识点总结PPT等资源,适合初学者

    Hibernate框架知识点的练习代码

    在本练习代码中,我们将深入探讨以下几个关键的Hibernate知识点: 1. **实体类和映射文件**:每个Java类代表数据库中的一个表,类的属性对应表的字段。通过XML映射文件(hibernate.cfg.xml)或注解,我们可以定义...

    Hibernate关键知识点大全

    【Hibernate关键知识点详解】 Hibernate是一款强大的Java持久化框架,它为开发者提供了在关系数据库与对象模型之间进行映射的能力,从而简化了数据访问层的开发。在这个知识点大全中,我们将深入探讨Hibernate的...

    hibernate的一份知识点总结

    ### Hibernate知识点总结 #### 一、Hibernate概述及入门 **1. HelloWorld** - **目的**:通过一个简单的示例,让初学者快速上手Hibernate,理解其基本工作流程。 - **步骤**: 1. 创建Java项目,命名为`...

    Hibernate知识文档 知识点笔记纪要

    《Hibernate知识文档 知识点笔记纪要》 在Java开发中,Hibernate是一个非常重要的ORM(Object-Relational Mapping)框架,它简化了数据库与Java对象之间的交互。本笔记主要涵盖了建立第一个Hibernate项目的步骤,...

    hibernate的学习笔记,hibernate所以知识点全,一看就能上手

    hibernate的学习笔记,hibernate所以知识点全,一看就能上手........包含代码和书写格式和图片分析~~~~hibernate的学习笔记,hibernate所以知识点全,一看就能上手........包含代码和书写格式和图片分析~~~~...

    JEECG HIBERNATE

    **JEECG HIBERNATE 知识点详解** JEECG是一款基于代码生成器的Java快速开发平台,它融合了各种主流开发框架和技术,旨在提高开发效率,降低开发成本。其中,`Hibernate`是JEECG的一个重要组成部分,它是Java领域中...

    hibernate入门数据简单插入

    ** Hibernate 知识点详解** 1. **对象关系映射(ORM)**:ORM是将关系数据库的数据模型转换为面向对象编程中的类和对象的技术,简化了数据库操作。Hibernate是Java领域中广泛使用的ORM框架之一。 2. **Hibernate...

    hibernate中文参考文档

    ### Hibernate中文参考文档知识点概述 ...通过以上对Hibernate知识点的详细介绍,可以帮助开发人员更好地理解和掌握其核心技术,从而在实际项目中更加高效地运用Hibernate解决复杂的数据库操作问题。

    Hibernate最详细的讲解

    **Hibernate 知识点详解** Hibernate 是一个开源的 Object-Relational Mapping (O/R Mapping) 框架,它提供了一种在 Java 应用程序中管理关系数据库模型的便捷方式。通过 Hibernate,开发者可以将数据库操作转化为...

    hibernate_second2项目源码

    此外,通过研究这个项目,还可以学习到其他相关的Hibernate知识点,如: - **实体类的设计**:如何创建符合Hibernate规范的Java Bean,包括主键生成策略、懒加载、瞬态与持久化状态等。 - **映射文件或注解的使用**...

    Hibernate3.1中文帮助文档

    **Hibernate知识点:** 1. **ORM框架**:Hibernate是一个流行的Java ORM框架,它消除了Java对象和关系数据库之间的语义差异,使得开发者可以使用面向对象的方式来处理数据库操作。 2. **持久化模型**:Hibernate的...

Global site tag (gtag.js) - Google Analytics