Hibernate是一个开源的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。
数据持久层是用来存取业务状态数据的,数据持久层最基本的功能是将数据持久化到存储到数据库里


开发步骤:

使用步骤:

类名.hbm.xml文件样式
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!--
<hibernate-mapping>一般不去配置,采用默认即可。
schema:指定映射数据库的schema(模式/数据库),如果指定该属性,则表名会自动添加该schema前缀
package:指定包前缀 指定持久化类所在的包名 这样之后calss子元素中就不必使用全限定性的类名
default-cascade="none":默认的级联风格,表与表联动。
default-lazy="true":默认延迟加载
-->
<hibernate-mapping package="com.lab1">
<!--
<class>:使用class元素定义一个持久化类。
name="cn.javass.user.vo.UserModel":持久化类的java全限定名;
table="tbl_user":对应数据库表名,默认持久化类名作为表名;
proxy:指定一个接口,在延迟装载时作为代理使用,也可在这里指定该类自己的名字。
mutable="true":默认为true,设置为false时则不可以被应用程序更新或删除,等价于所有<property>元素的update属性为false,表示整个实例不能被更新。
dynamic-insert="false":默认为false,动态修改那些有改变过的字段,而不用修改所有字段;
dynamic-update="false":默认为false,动态插入非空值字段;
select-before-update="false":默认为false,在修改之前先做一次查询,与用户的值进行对比,有变化都会真正更新;
optimistic-lock="version":默认为version(检查version/timestamp字段),取值:all(检查全部字段)、dirty(只检查修改过的字段);
none(不使用乐观锁定),此参数主要用来处理并发,每条值都有固定且唯一的版本,版本为最新时才能执行操作;
如果需要采用继承映射,则class元素下还会增加<subclass.../>元素等用于定义子类。
-->
<class name="Tstudent" table="tstudent" >
<!--
<id>:定义了该属性到数据库表主键字段的映射。
type 指定该标识属性的数据类型,该类型可以是Hibernate的内建类型,也可以是java类型,如果是java类型则需要使用全限定类名(带包名)。该属性可选,如果没有指定类型, 则hibernate自行判断该标识属性数据类型。通常建议设定。
name="userId":标识属性的名字;
column="userId":表主键字段的名字,如果不填写与name一样;
-->
<id name="sid" type="long" column="sid">
<generator class="assigned" />
</id>
<property name="sname" column="sname" />
<many-to-one name="tunit" column="unit_id" class="Tunit" not-null="true" cascade="all"></many-to-one>
</class>
</hibernate-mapping>
hibernate.cfg.xml样式
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 数据库连接:JDBC驱动 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 数据库连接:URL -->
<property name="hibernate.connection.url">jdbc:mysql://localhost/hibernate-database</property>
<!-- 数据库连接:用户名 -->
<property name="hibernate.connection.username">root</property>
<!-- 数据库连接:密码 -->
<property name="hibernate.connection.password">123456</property>
<!-- mysql数据库在hibernate中语言格式 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 自动生成数据库表结构 -->
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- 显示Hibernate生成的SQL语句 -->
<property name="hibernate.show_sql">true</property>
<!-- 映射表xml文件方式 -->
<mapping resource="com/lab1/Tunit.hbm.xml"/>
<mapping resource="com/lab1/Tstudent.hbm.xml"/>
<!--映射表注解方式-->
<mapping class="com.lab2.UserInfo"/>
</session-factory>
</hibernate-configuration>


多对一(一对多)

一对一:

多对多:



事务并发问题:

锁:

HQL:(半自动查询)

普通:

分页:

设置参数:

聚集函数:

Criteria查询:(全自动查询)

基本流程:

开始二级缓存


原文:https://www.cnblogs.com/lyt-echso/p/13125431.html