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


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,下午。

Hibernate知识点总结(一)的更多相关文章

  1. Hibernate知识点小结(三)-->一对多与多对多配置

    一.多表关系与多表设计 1.多表关系        一对一:            表的设计原则(分表原则):                优化表的性能                基于语意化分表 ...

  2. Hibernate知识点整理

    一, Hibernate 介绍: Hibernate 只是一个将持久化类与数据库表相映射的工具,每个持久化类实例均对应于数据库表中的一个数据行而已.用户只需直接使用面向对象的方法操作此持久化类实例,即 ...

  3. Hibernate 知识点梳理

    1.对持久化对象的要求 1)提供一个无参构造器 2)提供一个标识属性,如id,通常映射为数据库表的主键字段. 3)为持久化类的字段提供get.set方法. 注:但不一定所有字段都这么做,对于不提供ge ...

  4. hibernate知识点理解

    1.只有业务逻辑层出现的问题? 1.切换数据库麻烦 2.sql编写起来麻烦 3.我们的程序员不需要关注数据库,只希望关心业务本身 2.hibernate的好处 1.程序员只关心业务逻辑,使角色更加清楚 ...

  5. Hibernate知识点总结

    Hibernate配置二级缓存:  --- 使用EhCache 1.hibernate.cfg.xml中配置二级缓存 <hibernate-configuration>   <ses ...

  6. Hibernate 知识点复习

    核心接口 1  Configuration接口负责配置并启动Hibernate,创建SessionFactory对象 2  SessionFactory接口负责初始化Hibernate.它充当数据存储 ...

  7. Hibernate知识点小结汇总

    Hibernate部分 1.为什么要使用Hibernate开发你的项目呢?Hibernate的开发流程是怎么样的? 为什么要使用 ①.对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复 ...

  8. Hibernate知识点小结(四)--JPA

    一.jpa的简介和入门 JPA:Java Persistence API,接口规范    Hinernate内部为JPA规范提供实现        开发步骤(EntityManager):       ...

  9. Hibernate知识点小结(二)

    一.持久化对象和标识符    1.持久化类        配置完关系后,操作的实体对应的类,成为持久化类 (Customer) 2.持久化类标识符(oid:object id)        3.持久 ...

随机推荐

  1. 禅道导入bugfree 3.0的数据

    禅道项目导入bugfree功能只支持到2.0, 官方不提供3.0的导入,只好自己写了一个.因为bugfree 3.0换人开发了,表结构和禅道差别很大,所以,这个工具不是完全转换,一些History表内 ...

  2. element UI table 过滤 筛选问题

    一.问提描述    使用elementUI table 官方筛选案例,发现筛选不是服务器端筛选,而是浏览器端对每一页进行单独筛选. 如何在服务器端筛选? 二.查询Element UI 官网table组 ...

  3. [Linux] 简单安装和使用composer

    wget https://getcomposer.org/installer //下载一个脚本文件 php installer //php执行下这个php脚本 mv composer.phar /us ...

  4. MATLAB R2017a 进入主界面以后一直处于初始化状态的解决办法

    自从前几天更新了win10系统,结果发现matlab不能用了,进入主界面一直初始化,没完没了. 网上说可能是许可证等问题,但经过尝试发现仍然无法解决问题. 仔细一想,发现win10系统的防火墙默默把它 ...

  5. 5. CopyOnWriteArrayList 的适用场景

    package com.gf.demo04; import java.util.ArrayList; import java.util.Collections; import java.util.It ...

  6. 【Java每日一题】20170306

    20170303问题解析请点击今日问题下方的“[Java每日一题]20170306”查看(问题解析在公众号首发,公众号ID:weknow619) package Mar2017; public cla ...

  7. 【Java每日一题】20170215

    20170214问题解析请点击今日问题下方的“[Java每日一题]20170215”查看(问题解析在公众号首发,公众号ID:weknow619) package Feb2017; public cla ...

  8. mybatis笔记01

    目录 1. Mybatis的介绍 2. 使用JDBC编码的分析 2.1 准备 2.3 程序代码 2.4 JDBC问题 3. Mybatis架构 4. Mybatis入门程序 4.1 mybatis下载 ...

  9. 元类实现ORM

    1. ORM是什么 ORM 是 python编程语言后端web框架 Django的核心思想,"Object Relational Mapping",即对象-关系映射,简称ORM. ...

  10. idea项目git版本回退

    idea项目git版本回退 一.查询提交历史 项目上右键,点击Git,点击Show History 二.复制版本号 我这里有两个测试的版本,我的当前版本是[二],所以我选择[一],右键,选择Copy ...