Hibernate知识点总结(一)

时间:2023-03-08 17:40:46

前言:学习的过程在于不断的总结与思考,这里记下笔者在学习过程中,所遇到的知识点,增加对框架掌握的熟悉程度。


1.环境的搭建

通过maven可以轻松搭建hibernate的环境。

 <properties>
<hibernate.version>5.1.12.Final</hibernate.version>
<junit.version>4.12</junit.version>
<mysql.version>5.1.38</mysql.version>
<log4j.version>1.2.17</log4j.version>
<slf4j.version>1.7.25</slf4j.version>
</properties> <dependencies>
<!-- hibernate依赖-->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>${hibernate.version}</version>
</dependency> <!-- 数据库驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<!-- log4j-->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${slf4j.version}</version>
</dependency> <!-- 测试依赖-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
</dependency>
</dependencies>

2.hibernate中实体类的映射配置文件

其名称和位置没有特别要求,笔者偏向专门的一个包,来放置映射文件。其命名规则为:

实体类名.hbm.xml,其配置文件中为dtd约束,需要引入相应的约束条件:

实体类映射配置文件需引入:

<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

hibernate核心配置文件需引入:

<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

hibernate核心配置文件,位置和名称都固定

位置:src下

名称:hibernate.cfg.xml

3.hibernate核心配置文件主要配置

  <session-factory>
<!-- 主要三部分配置-->
<!-- 1.配置数据库信息,必须的-->
<property name="connection.url">jdbc:mysql://127.0.0.1:3307/hibernatestudy?useUnicode=true&amp;characterEncoding=UTF-8</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.username">root</property>
<property name="connection.password"></property> <!-- 2.配置hibernate信息,可选的--> <!-- 输出底层的sql语句-->
<property name="hibernate.show_sql">true</property> <!-- 对底层sql进行格式化-->
<property name="hibernate.format_sql">true</property> <!--配置数据的方言,如mysql中limit
oracle的rownum-->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> <!-- 配置本地线程绑定的session-->
<property name="hibernate.current_session_context_class">thread</property> <!-- 3.把映射文件配置到核心文件中,必须的-->
<!-- 有多个xml文件就添加多个-->
<mapping resource="com/xxx/domain/hbm/xml/User.hbm.xml"/> </session-factory>

4.实体类映射文件的配置

 <!--1.配置类和表对应
class标签
name属性:实体类的全路径
table属性:数据库表名称
-->
<class name="com.xxx.domain.User" table="t_user"> <!-- 2.配置类的id和表的id对应
hibernate要求实体类有一个属性唯一值
hibernate要求表字段作为唯一值
相当于主键的配置
-->
<!-- id标签
name属性:实体类里面id的属性名称
column属性:表的字段名称
-->
<id name="uid" column="uid">
<!-- 配置id的增长策略
native表示表的主键为自动增长
-->
<!--<generator class="native"/>-->
<generator class="uuid"/> <!--uuid模式的自动生成-->
</id>
<!-- 配置其他属性值和表对应-->
<property name="username" column="t_username"/>
<property name="password" column="t_password"/>
<property name="address" column="t_address"/>
</class>

5.hibernate中实体类对象的三种状态

瞬时态:实体类对象与session没有关联,如刚创建的对象

持久态:实体类对象与session有关联,并且拥有数据库标识(拥有主键值)

脱管态:当持久态对象的session关闭后,此时该实体类对象就是脱管态

在session的saveOrUpdate操作时,当实体类对象为瞬时态时,做save操作,当实体类对象为其他两种状态时,做update操作。

6.hibernate缓存

缓存是指为了降低应用程序对物理数据源访问的频次从而提高应用程序的运行性能的一种策略。

hibernate一级缓存:

hibernate中一级缓存默认打开,使用范围为session范围,从session创建到session关闭,一级缓存中,存储的数据必须是持久态的数据对象。

hibernate二级缓存:

hibernate中二级缓存默认不开启,需要进行配置,可以redis代替

一级缓存的执行过程:

在取数据的时候,第一次从一级缓存中查询,如果没有值,则从数据库中获取,当查询出结果后,放入一级缓存,当第二次查询相同结果时,则从一级缓存中得到结果。

一级缓存的特性:

做数据修改时,持久态实体类对象会自动更新到数据库。

在一级缓存创建的同时,会创建快照区,在修改持久态实体类对象时,只会修改一级缓存的值,不会修改快照区中的值。

在提交事务时,会比较一级缓存和快照区的值,如果两个值不相同,则会更新数据到数据库中,如果两个值相同,则不会将数据更新到数据库中。

7.hibernate中session的绑定

绑定本地session需在hibernate核心配置文件中进行配置,在操作本地绑定的session时,不需要对其进行关闭,在该线程执行完毕后,该session会自动关闭。

绑定本地session的配置语句:

<property name="hibernate.current_session_context_class">thread</property>

8.hibernate中查询API

hql查询:hibernate query language

hql与sql语句非常的相似,hql操作的是实体类和其属性,sql操作的是数据表和字段(实体类对应表,属性对应字段)

使用hql语句,需要使用Query对象,通过session创建,一些基本的查询方式:

查询所有:from 实体类名称

条件查询:from 实体类名称 where 属性名称1=?and 属性名称2=?

然后通过Query对象的setParameter(int,object)对占位符进行值得设置,注意占位符?的位置值从0开始

排序查询:from 实体类名称 order by 属性值 asc(desc)

分页查询:(hibernate中不识别limit)from 实体类名称,然后通过Query对象的相关方法进行分页数据的设置

setFirstResult设置开始记录位置,setMaxResults设置每页显示的数据条数

注:开始记录位置计算公式(当前页-1)*每页显示的记录数

投影查询:查询部分字段的值,如 select columnname from tablename

hql语句的写法:select 属性值名称1,属性值名称2 from 实体类名称,hql中不支持select *。

聚函数的使用:select count(*) from 实体类名称,注意使用Query对象的uniqueResult方法的使用,如果是查询总数,注意Long对象的转换。

QBC查询:Query By Criteria

QBC查询不需要写任何语句,直接使用Criteria对象提供的相关方法,进行操作即可,其操作的也是实体类。

QBC中条件查询,需要使用Restrictions对象进行操作

QBC中分页查询和hql有点类似利用setFirstResult设置开始记录位置,setMaxResults设置每页显示的数据条数

本地sql查询

本地sql查询就是通过原生sql语句进行数据库的查询,需要使用SQLQuery对象进行相关操作。


by Shawn chen,2018.2.28,下午。