Hibernate学习笔记一:Hibernate框架的搭建与配置,Hibernate的各个对象理解

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_33322074/article/details/89030088

Hibernate学习笔记一:Hibernate框架的搭建与配置

Hibernate框架意义

  1. hibernate框架是用来提高开发效率的,封装了大量操作数据库的语句,达到了面向对象方式的操作数据库的方式。

Hibernate框架

  1. Hibernate框架的出现用来替换jdbc,DBUtils技术的,不需要再书写sql语句了。

hibernate框架

搭建Hibernate框架

  1. 导入hibernate必要的jar包

导入的核心包

  1. 创建数据库,准备表,实体,对应表的映射文件
  2. 引入hibernate必要的dtd约束

导入约束参考网站

  1. 书写hibernate.cfg.xml主配置文件

在ClassPath路径下书写hibernate.cfg.xml这是主配置文件

  1. 引入约束信息–注意这个是cfg.xml应当导入hibernate-configuration-3.0.dtd的约束信息而hibernate.hbm.xml是表与实体映射文件,应当导入hibernate-mapping-3.0.dtd信息。
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
  1. 书写数据库部分(必选)
<!-- 数据库驱动 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 数据库url -->
<property name="hibernate.connection.url">jdbc:mysql:///hibernate_32</property>
<!-- 数据库连接用户名 -->
<property name="hibernate.connection.username">root</property>
<!-- 数据库连接密码 -->
<property name="hibernate.connection.password">1234</property>
<!-- 数据库方言配置-->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
  • 上面5个配置是必须写的
  1. 数据库其他配置语(3个可选)
<!-- 将hibernate生成的sql语句打印到控制台 -->
<property name="hibernate.show_sql">true</property>
<!-- 将hibernate生成的sql语句格式化(语法缩进) -->
<property name="hibernate.format_sql">true</property>
<!-- 
  ## auto schema export  自动导出表结构. 自动建表
  #hibernate.hbm2ddl.auto create		自动建表.每次框架运行都会创建新的表.以前表将会被覆盖,表数据会丢失.(开发环境中测试使用)
  #hibernate.hbm2ddl.auto create-drop 自动建表.每次框架运行结束都会将所有表删除.(开发环境中测试使用)
  #hibernate.hbm2ddl.auto update(推荐使用) 自动生成表.如果已经存在不会再生成.如果表有变动.自动更新表(不会删除任何数据).
  #hibernate.hbm2ddl.auto validate	校验.不自动生成表.每次启动会校验数据库中表是否正确.校验失败. -->
<property name="hibernate.hbm2ddl.auto">update</property>
  1. 引入orm元数据路径部分,将映射文件路径导入到cfg.xml中
<mapping resource="cn/itheima/domain/Customer.hbm.xml" />
  1. 总代码展示:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
	<session-factory>
		<!-- 
		#hibernate.dialect org.hibernate.dialect.MySQLDialect
		#hibernate.dialect org.hibernate.dialect.MySQLInnoDBDialect
		#hibernate.dialect org.hibernate.dialect.MySQLMyISAMDialect
		#hibernate.connection.driver_class com.mysql.jdbc.Driver
		#hibernate.connection.url jdbc:mysql:///test
		#hibernate.connection.username gavin
		#hibernate.connection.password
		 -->
		 <!-- 数据库驱动 -->
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		 <!-- 数据库url -->
		<property name="hibernate.connection.url">jdbc:mysql:///hibernate_32</property>
		 <!-- 数据库连接用户名 -->
		<property name="hibernate.connection.username">root</property>
		 <!-- 数据库连接密码 -->
		<property name="hibernate.connection.password">1234</property>
		<!-- 数据库方言
			不同的数据库中,sql语法略有区别. 指定方言可以让hibernate框架在生成sql语句时.针对数据库的方言生成.
			sql99标准: DDL 定义语言  库表的增删改查
					  DCL 控制语言  事务 权限
					  DML 操纵语言  增删改查
			注意: MYSQL在选择方言时,请选择最短的方言.
		 -->
		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
		<!-- #hibernate.show_sql true 
			 #hibernate.format_sql true
		-->
		<!-- 将hibernate生成的sql语句打印到控制台 -->
		<property name="hibernate.show_sql">true</property>
		<!-- 将hibernate生成的sql语句格式化(语法缩进) -->
		<property name="hibernate.format_sql">true</property>
		<!-- 
		## auto schema export  自动导出表结构. 自动建表
		#hibernate.hbm2ddl.auto create		自动建表.每次框架运行都会创建新的表.以前表将会被覆盖,表数据会丢失.(开发环境中测试使用)
		#hibernate.hbm2ddl.auto create-drop 自动建表.每次框架运行结束都会将所有表删除.(开发环境中测试使用)
		#hibernate.hbm2ddl.auto update(推荐使用) 自动生成表.如果已经存在不会再生成.如果表有变动.自动更新表(不会删除任何数据).
		#hibernate.hbm2ddl.auto validate	校验.不自动生成表.每次启动会校验数据库中表是否正确.校验失败.
		 -->
		<property name="hibernate.hbm2ddl.auto">update</property>
		<!-- 引入orm元数据
			路径书写: 填写src下的路径
		 -->
		<mapping resource="cn/itheima/domain/Customer.hbm.xml" />
	</session-factory>
</hibernate-configuration>

hibernate.hbm.xml的书写(orm元数据文件的配置)

  1. hibernate.hbm.xml包含根元素、class元素、id元素、property元素,要导入约束信息
<hibernate-mapping package="cn.xxx.domain" >
  • 这个主要指定包名,好处是下面不需要再带包名了。
  1. class元素
<class name="Customer" table="cst_customer" >
  • name是对应的实体名字,table是对应的数据库表名,形成映射
  1. id元素
<id name="cust_id" column:"cust_id">
    <!-- generator:主键生成策略(明天讲) -->
    <generator class="native"></generator>
</id>
  • id配置的是主键映射机制,name是实体类的属性,column:配置的是表的主键。
  • name: 填写主键对应属性名
    column(可选): 填写表中的主键列名.默认值:列名会默认使用属性名
    type(可选):填写列(属性)的类型.hibernate会自动检测实体的属性类型.
    每个类型有三种填法: java类型|hibernate类型|数据库类型
    not-null(可选):配置该属性(列)是否不能为空. 默认值:false
    length(可选):配置数据库中列的长度. 默认值:使用数据库类型的最大长度
  1. propety元素,普通属性,列名的映射
<property name="cust_source" column="cust_source" ></property>
  • property元素:除id之外的普通属性映射
    name: 填写属性名
    column(可选): 填写列名
    type(可选):填写列(属性)的类型.hibernate会自动检测实体的属性类型.
    每个类型有三种填法: java类型|hibernate类型|数据库类型
    not-null(可选):配置该属性(列)是否不能为空. 默认值:false
    length(可选):配置数据库中列的长度. 默认值:使用数据库类型的最大长度

Hibernate框架API详解

Configuration对象详解

  1. Configuration功能: 配置加载类.用于加载主配置,orm元数据加载
  2. 创建Configuration对象(利用对象方式)
//1 创建,调用空参构造
Configuration conf = new Configuration();
  1. 加载主配置文件hibernate.cfg.xml
//2 读取指定主配置文件 => 空参加载方法,加载src下的hibernate.cfg.xml文件
conf.configure();
  1. 加载orm元数据–这个已经过时了,因为元数据已经在hibernate.cfg.xml中了
//3 读取指定orm元数据(扩展),如果主配置中已经引入映射配置.不需要手动加载
//conf.addResource(resourceName);
//conf.addClass(persistentClass);
  1. 通过Configuration创建SessionFactory对象
//4 根据配置信息,创建 SessionFactory对象
SessionFactory sf = conf.buildSessionFactory();

SessionFactory对象的创建

  1. SessionFactory对象的作用
  • session对象功能: 表达hibernate框架与数据库之间的连接(会话).session类似于JDBC年代的connection对象. 还可以完成对数据库中数据的增删改查操作.session是hibernate操作数据库的核心对象
  • SessionFactory消耗内存,尽量一个Web项目只创建一个SessionFactory对象。
  1. 获取session
Session session = sf.openSession();
//4 session获得操作事务的Transaction对象
//获得操作事务的tx对象
//Transaction tx = session.getTransaction();
//开启事务并获得操作事务的tx对象(建议使用)
Transaction tx2 = session.beginTransaction();
  1. 提交事务,回滚事务
tx2.commit();//提交事务
tx2.rollback();//回滚事务
session.close();//释放资源
sf.close();//释放资源
  1. 添加资源
Transaction tx2 = session.beginTransaction();
//----------------------------------------------
Customer c = new Customer();
c.setCust_name("xxxxx");
session.save(c);
//----------------------------------------------
tx2.commit();//提交事务
  1. 查询资源
Transaction tx2 = session.beginTransaction();
//----------------------------------------------
Customer customer = session.get(Customer.class, 1l);
System.out.println(customer);
//----------------------------------------------
tx2.commit();//提交事务
  1. 修改资源
Transaction tx2 = session.beginTransaction();
//----------------------------------------------
//1 获得要修改的对象
Customer c = session.get(Customer.class, 1l);
//2 修改
c.setCust_name("xxxx");
//3 执行update
session.update(c);
//----------------------------------------------
tx2.commit();//提交事务
  1. 删除资源
Transaction tx2 = session.beginTransaction();
//----------------------------------------------
//1 获得要修改的对象
Customer c = session.get(Customer.class, 1l);
//2 调用delete删除对象
session.delete(c);
//----------------------------------------------
tx2.commit();//提交事务

制作hibernateUtils工具类封装反复使用的代码

  1. 主要封装Configuration,Session的获取
  2. 难点:要保证一个项目中只创建一个SessionFactory对象。通过Static代码块来解决
  3. static代码块会在类加载时执行,类是由类的加载器读取的,类加载器带有一个缓存区,他会把读取到的类缓存起来,所以在一次jvm运行期间一个类只会被加载一次,这样静态代码块就会被执行一次。
  4. 代码:
public class HibernateUtils {
private static SessionFactory sf;//写在外面全局使用
static{//static代码块只执行一次
    //1 创建,调用空参构造
    Configuration conf = new Configuration().configure();
    //2 根据配置信息,创建 SessionFactory对象
    sf = conf.buildSessionFactory();
}
//获得session => 获得全新session
public static Session openSession(){
    //3 获得session
    Session session = sf.openSession();
    return session;
}
//获得session => 获得与线程绑定的session
public static Session getCurrentSession(){
    //3 获得session
    Session session = sf.getCurrentSession();
    return session;
}}

小技巧

  1. eclipse快捷键Ctrl+1,将鼠标停在该类上,按快捷键可以提示生成方法,类什么的。

猜你喜欢

转载自blog.csdn.net/qq_33322074/article/details/89030088
今日推荐