Hibernate第一天(Hibernate的环境搭建、Hibernate的API、Hibernate的CRUD)

Hibernate的入门(Hibernate的环境搭建、Hibernate的API、Hibernate的CRUD)

以前学习过Hibernate,不过学习的不太扎实,做的项目也不太多,好久时间没用,都快忘得差不多了,今天重新学习一下,一步一个脚印的敲每个代码,争取把Hibernate彻底学明白。

 

 

目录

Hibernate的入门(Hibernate的环境搭建、Hibernate的API、Hibernate的CRUD)

 

 

1.1     Hibernate框架的学习路线

 

1.2     Hibernate的框架的概述

1.2.1  什么是框架

1.2.2  EE的经典三层结构

1.3  Hibernate的概述

1.3.1       什么是Hibernate

1.3.2       什么是ORM

1.3.3       为什么要学习Hibernate

1.4     Hibernate的入门

1.4.1  Hibernate的入门

1.5     Hibernate的常见配置

1.5.1  XML提示的配置

1.5.2  Hibernate的映射的配置

1.5.3  Hibernate的核心的配置

1.6     Hibernate的核心API

1.6.1  Hibernate的API

源码地址:


1.1     Hibernate框架的学习路线

     第一天:Hibernate的入门(Hibernate的环境搭建、Hibernate的API、Hibernate的CRUD)

     第二天:Hibernate的一级缓存、其他的API

     第三天:Hibernate的一对多配置、Hibernate的多对多的配置

     第四天:Hibernate的查询方式、抓取策略

 

 

1.2     Hibernate的框架的概述

1.2.1  什么是框架

框架:指的是软件的半成品,已经完成了部分功能。

1.2.2  EE的经典三层结构

 

1.3  Hibernate的概述

1.3.1       什么是Hibernate

 

Hibernate:Hibernate是一个持久层的ORM框架。

1.3.2       什么是ORM

ORM:Object Relational Mapping(对象关系映射)。指的是将一个Java中的对象与关系型数据库中的表建立一种映射关系,从而操作对象就可以操作数据库中的表。

1.3.3       为什么要学习Hibernate

 

1.4     Hibernate的入门

1.4.1  Hibernate的入门

1.4.1.1       下载Hibernate的开发环境

Hibernate3.x  Hibernate4.x  Hibernate5.x(我这里使用5.0.7

 

下载地址:https://sourceforge.net/projects/hibernate/files/hibernate-orm/5.0.7.Final/

1.4.1.2       解压Hibernate

     1.documentation              :Hibernate开发的文档

     2.lib                                       :Hibernate开发包

            2.1required                           :Hibernate开发的必须的依赖包

            2.2optional                            :Hibernate开发的可选的jar

     3.project                              :Hibernate提供的项目

1.4.1.3       创建一个项目,引入jar包

     1.数据库驱动包,2.Hibernate开发的必须的jar包,3.Hibernate引入日志记录包,4.C3p0连接池

 

 

1.4.1.4       创建表

CREATE TABLE `cst_customer` (

  `cust_id` bigint(32) NOT NULL AUTO_INCREMENT COMMENT '客户编号(主键)',

  `cust_name` varchar(32) NOT NULL COMMENT '客户名称(公司名称)',

  `cust_source` varchar(32) DEFAULT NULL COMMENT '客户信息来源',

  `cust_industry` varchar(32) DEFAULT NULL COMMENT '客户所属行业',

  `cust_level` varchar(32) DEFAULT NULL COMMENT '客户级别',

  `cust_phone` varchar(64) DEFAULT NULL COMMENT '固定电话',

  `cust_mobile` varchar(16) DEFAULT NULL COMMENT '移动电话',

  PRIMARY KEY (`cust_id`)

) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

1.4.1.5       创建实体类

 

1.4.1.6       创建映射(*****)

映射需要通过XML的配置文件来完成,这个配置文件可以任意命名。尽量统一命名规范(类名.hbm.xml

 

Customer映射文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<!-- 建立类与表的映射 -->
	<!--
	class标签:用来建立类和表的映射
	      *name属性:类的全路径
		  *table属性:表名(如果表名和类名一致可忽略)
		  *catalog属性:数据库名称,可忽略
    -->
	<class name="top.yangxianyang.demo1.Customer" table="cst_customer">
		<!-- 建立类中的属性与表中的主键对应 -->
		<!--
		 id标签:建立类中的属性与表中的主键对应
		    *name属性:类中的属性名
		    *column属性:表中字段名(如果类中属性名和表中字段名一致,可省略)
		    *catalog属性:数据库名称,可忽略 
			*length属性:字段长度
			*type属性:类型。写Java数据类型,Hibernate数据类型(默认),SQL类型
		-->
		<id name="cust_id" column="cust_id" >
			<!-- 主键生成策略 -->
			<generator class="native"/>
		</id>
		
		<!-- 建立类中的普通的属性和表的字段的对应 -->
		<!--
		 property标签:建立类中的普通的属性和表的字段的对应
		    *name属性:类中的属性名
		    *column属性:表中字段名(如果类中属性名和表中字段名一致,可省略)
		    *length属性:字段长度
			*type属性:类型。写Java数据类型,Hibernate数据类型(默认),SQL类型
		-->
		<property name="cust_name" column="cust_name" length="32" />
		<property name="cust_source" column="cust_source" length="32"/>
		<property name="cust_industry" column="cust_industry"/>
		<property name="cust_level" column="cust_level"/>
		<property name="cust_phone" column="cust_phone"/>
		<property name="cust_mobile" column="cust_mobile"/>
	</class>
</hibernate-mapping>

1.4.1.7       创建一个Hibernate的核心配置文件(*****)

Hibernate的核心配置文件的名称:hibernate.cfg.xml

 

<?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>
		<!-- 连接数据库的基本参数 -->
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="hibernate.connection.url">jdbc:mysql:///sshstudy</property>
		<property name="hibernate.connection.username">yxy</property>
		<property name="hibernate.connection.password">123456</property>
		<!-- 配置Hibernate的方言:作用,根据配置的方言生成相应的SQL语句 -->
		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
		
		<!-- 可选配置================ -->
		<!-- 打印SQL -->
		<property name="hibernate.show_sql">true</property>
		<!-- 格式化SQL -->
		<property name="hibernate.format_sql">true</property>
		<!-- 自动创建表 	
						none:不使用hibernate的自动建表
	                    create:如果数据库中已经有表,删除原有表,重新创建,如果没有表,新建表。(测试)
	                    create-drop	:如果数据库中已经有表,删除原有表,执行操作,删除这个表。如果没有表,新建一个,使用完了删除该表。(测试)
						update:如果数据库中有表,使用原有表,如果没有表,创建新表(更新表结构)
						validate:如果没有表,不会创建表。只会使用数据库中原有的表。(校验映射和表结构)。
		-->
		<property name="hibernate.hbm2ddl.auto">update</property>
		
		
		<!-- 配置C3P0连接池 -->
		<property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
		<!--在连接池中可用的数据库连接的最少数目 -->
		<property name="c3p0.min_size">5</property>
		<!--在连接池中所有数据库连接的最大数目  -->
		<property name="c3p0.max_size">20</property>
		<!--设定数据库连接的过期时间,以秒为单位,
		如果连接池中的某个数据库连接处于空闲状态的时间超过了timeout时间,就会从连接池中清除 -->
		<property name="c3p0.timeout">120</property>
		 <!--每3000秒检查所有连接池中的空闲连接 以秒为单位-->
		<property name="c3p0.idle_test_period">3000</property>
		
		
		
		<!-- 加载映射  -->
		<mapping resource="top/yangxianyang/demo1/Customer.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

 

1.4.1.8       编写测试代码(*****)

package top.yangxianyang.demo1;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;

/**
 * Hibernate的入门案例
 * @author yxy
 *
 */
public class Test1 {
	public static void main(String[] args) {
		demo1();
	}

	// 保存客户
	public static void demo1() {
		// 1.加载Hibernate的核心配置文件
		Configuration configuration = new Configuration().configure();
		// 2.创建一个SessionFactory对象:类似于JDBC中连接池
		SessionFactory sessionFactory = configuration.buildSessionFactory();
		// 3.通过SessionFactory获取到Session对象:类似于JDBC中Connection
		Session session = sessionFactory.openSession();
		// 4.手动开启事务:
		Transaction transaction = session.beginTransaction();
		// 5.编写代码

		Customer customer = new Customer();
		customer.setCust_name("王小红");

		session.save(customer);

		// 6.事务提交
		transaction.commit();
		// 7.资源释放
		session.close();
		sessionFactory.close();
	}
}

 

1.5     Hibernate的常见配置

1.5.1  XML提示的配置

1.5.1.1       配置XML提示问题

 

 

 

 

 

 

1.5.2  Hibernate的映射的配置

1.5.2.1       映射的配置

  1. 【class标签的配置】
    1. 标签用来建立类与表的映射关系
    2. 属性:
      1. name                 :类的全路径
      2. table                  :表名(类名与表名一致,table可以省略)
      3. catalog              :数据库名
  2. 【id标签的配置】
    1. 标签用来建立类中的属性与表中的主键的对应关系
    2. 属性:
      1. name                 :类中的属性名
      2. column              :表中的字段名(类中的属性名和表中的字段名如果一致,column可以省略)
      3. length                :长度
      4. type                    :类型
  3. 【property标签的配置】
    1. 标签用来建立类中的普通属性与表的字段的对应关系
    2. 属性:
      1. name                 :类中的属性名
      2. column              :表中的字段名
      3. length                :长度
      4. type                    :类型
      5. not-null              :设置非空
      6. unique               :设置唯一

1.5.3  Hibernate的核心的配置

1.5.3.1       Hibernate的核心配置方式(了解)

     一种方式:属性文件的方式

     hibernate.properties

     hibernate.connection.driver_class=com.mysql.jdbc.Driver

     …

     hibernate.show_sql=true

     属性文件的方式不能引入映射文件(手动编写代码加载映射文件)

 

     二种方式:XML文件的方式

     hibernate.cfg.xml(推荐)

1.5.3.2       核心的配置

  1. 必须的配置
    1. 连接数据库的基本的参数
      1. 驱动类
      2. url路径
      3. 用户名
      4. 密码
    2. 方言
  2. 可选的配置
    1. 显示SQL           :hibernate.show_sql
    2. 格式化SQL      :hibernate.format_sql
    3. 自动建表         :hibernate.hbm2ddl.auto
      1. none                   :不使用hibernate的自动建表
      2. create                :如果数据库中已经有表,删除原有表,重新创建,如果没有表,新建表。(测试)
      3. create-drop      :如果数据库中已经有表,删除原有表,执行操作,删除这个表。如果没有表,新建一个,使用完了删除该表。(测试)
      4. update              :如果数据库中有表,使用原有表,如果没有表,创建新表(更新表结构)
      5. validate            :如果没有表,不会创建表。只会使用数据库中原有的表。(校验映射和表结构)。
  3. 映射文件的引入     
    1. 引入映射文件的位置

 

1.6     Hibernate的核心API

1.6.1  Hibernate的API

1.6.1.1       Configuration:Hibernate的配置对象

 

作用:

加载核心配置文件

1.hibernate.properties

Configuration cfg = new Configuration();

2.hibernate.cfg.xml

Configuration cfg = new Configuration().configure();

 

 

 

1.6.1.2       SessionFactory:Session工厂

 

SessionFactory内部维护了Hibernate的连接池和Hibernate的二级缓存。是线程安全的对象。一个项目创建一个对象即可。

 

  1. 封装工具类


 

package com.itheima.hibernate.utils;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

/**
 * Hibernate的工具类
 * @author yxy
 *
 */
public class HibernateUtils {

	public static final Configuration cfg;
	public static final SessionFactory sf;
	
	static{
		cfg = new Configuration().configure();
		sf = cfg.buildSessionFactory();
	}
	/*
	 * 提供获得session的方法
	 */
	public static Session openSession(){
		return sf.openSession();
	}
}

 

 

1.6.1.3       Session:类似Connection对象是连接对象

 

Session代表的是Hibernate与数据库的链接对象。不是线程安全的。与数据库交互桥梁。

  1. Session中的API
    1. 保存方法:
      1. Serializable save(Object obj);
    2. 查询方法:
      1. T get(Class c,Serializable id);
      2. T load(Class c,Serializable id);
      3. get方法和load方法的区别?

 

 get方法

         *      * 采用的是立即加载,执行到这行代码的时候,就会马上发送SQL语句去查询。

                    *  * 查询后返回是真实对象本身。

                    *   * 查询一个找不到的对象的时候,返回null

 

load方法

                   *      * 采用的是延迟加载(lazy懒加载),执行到这行代码的时候,不会发送SQL语句,当真正使用这个对象的时候才会发送SQL语句。

                    *  * 查询后返回的是代理对象。javassist-3.18.1-GA.jar 利用javassist技术产生的代理。

                    *  * 查询一个找不到的对象的时候,返回ObjectNotFoundException

        

 

  1. 修改方法
    1. void update(Object obj);

 

    1. 删除方法
      1. void delete(Object obj);

 

    1. 保存或更新
      1. void saveOrUpdate(Object obj)

 

    1. 查询所有
      1. List createSQLQuery(String sql)

 

测试代码:

package top.yangxianyang.demo1;

import java.io.Serializable;
import java.util.Arrays;
import java.util.List;

import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test;

import com.itheima.hibernate.utils.HibernateUtils;

/**
 * Hibernate的工具类的测试
 * @author yxy
 *
 */
public class TestUtils {

	@Test
	// 保存客户
	public void demo1(){
		Session session = HibernateUtils.openSession();
		Transaction tx = session.beginTransaction();
		
		Customer customer  = new Customer();
		customer.setCust_name("王小西");
		Serializable id = session.save(customer);
		System.out.println(id);
		tx.commit();
		session.close();
	}
	
	@Test
	// 查询:
	// ***** get方法和load方法的区别
	public void demo2(){
		Session session = HibernateUtils.openSession();
		Transaction tx = session.beginTransaction();
		/**
		 * get方法
		 * 	* 采用的是立即加载,执行到这行代码的时候,就会马上发送SQL语句去查询。
		 *  * 查询后返回是真实对象本身。
		 * 	* 查询一个找不到的对象的时候,返回null
		 * 
		 * load方法
		 * 	* 采用的是延迟加载(lazy懒加载),执行到这行代码的时候,不会发送SQL语句,当真正使用这个对象的时候才会发送SQL语句。
		 *  * 查询后返回的是代理对象。javassist-3.18.1-GA.jar 利用javassist技术产生的代理。
		 *  * 查询一个找不到的对象的时候,返回ObjectNotFoundException
		 */
		// 使用get方法查询
		/*Customer customer = session.get(Customer.class, 1l); // 发送SQL语句
		System.out.println(customer);*/
		
		// 使用load方法查询
		Customer customer = session.load(Customer.class, 1l);
		System.out.println(customer);
		
		tx.commit();
		session.close();
	}
	
	@Test
	// 修改操作
	public void demo3(){
		Session session = HibernateUtils.openSession();
		Transaction tx = session.beginTransaction();
		
		// 直接创建对象,进行修改
		/*Customer customer = new Customer();
		customer.setCust_id(1l);
		customer.setCust_name("王聪");
		session.update(customer);*/
		
		// 先查询,再修改(推荐)
		Customer customer = session.get(Customer.class, 1l);
		customer.setCust_name("王小贱");
		session.update(customer);
		
		tx.commit();
		session.close();
	}
	
	@Test
	// 删除操作
	public void demo4(){
		Session session = HibernateUtils.openSession();
		Transaction tx = session.beginTransaction();
		
		// 直接创建对象,删除
	/*	Customer customer = new Customer();
		customer.setCust_id(1l);
		session.delete(customer);*/
		
		// 先查询再删除(推荐)--级联删除
		Customer customer = session.get(Customer.class, 2l);
		session.delete(customer);
		
		tx.commit();
		session.close();
	}
	
	@Test
	// 保存或更新
	public void demo5(){
		Session session = HibernateUtils.openSession();
		Transaction tx = session.beginTransaction();
		
		/*Customer customer  = new Customer();
		customer.setCust_name("王凤");
		session.saveOrUpdate(customer);*/
		
		Customer customer = new Customer();
		customer.setCust_id(3l);
		customer.setCust_name("李如花");
		session.saveOrUpdate(customer);
		
		tx.commit();
		session.close();
	}
	
	@Test
	// 查询所有
	public void demo6(){
		Session session = HibernateUtils.openSession();
		Transaction tx = session.beginTransaction();
		// 接收HQL:Hibernate Query Language 面向对象的查询语言
		/*Query query = session.createQuery("from Customer");
		List<Customer> list = query.list();
		for (Customer customer : list) {
			System.out.println(customer);
		}*/
		
		// 接收SQL:
		SQLQuery query = session.createSQLQuery("select * from cst_customer");
		List<Object[]> list = query.list();
		for (Object[] objects : list) {
			System.out.println(Arrays.toString(objects));
		}
		tx.commit();
		session.close();
	}
}

 

 

1.6.1.4       Transaction:事务对象

Hibernate中管理事务的对象。

     commit();

     rollback();

 

源码地址:

链接:https://pan.baidu.com/s/1cYbNGrbGu3NPOiIPTpzqOw 密码:y8kj

在图书馆看了几个小时终于整完了,基本框架搭建,环境配置成功,配置了C3P0连接池,封装了工具类,明天继续。

posted @ 2018-11-19 16:58  AlbertYang666  阅读(113)  评论(0编辑  收藏  举报

AlbertYang