Hibernate01
来源:互联网 发布:mysql安装教程5.7.20 编辑:程序博客网 时间:2024/05/21 10:23
1.Hibernate概述
1.1 Hibernate框架的概述
Hibernate是一个开放源代码的对象关系映射(ORM)框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用。 Hibernate是轻量级JavaEE应用的持久层解决方案,是一个关系数据库ORM框架 记住:Hibernate是一个持久层的ORM框架!!!
1.2 什么是ORM(对象关系映射)
ORM映射:Object Relational Mapping
O:面向对象领域的Object(JavaBean对象)
R:关系数据库领域的Relational(表的结构)
M:映射Mapping(XML的配置文件)
将数据表的关系,映射为类和对象之间关系: 数据库(关系型) Java(面向对象的编程语言) 表 类 表的字段 类的属性 表的一行数据 类的一个实例对象
简单一句话:Hibernate框架使程序员通过操作对象的方式来操作数据库中表的记录1.3 Hibernate优点
Hibernate对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码
Hibernate是一个基于jdbc的主流持久化框架,是一个优秀的orm实现,它很大程度的简化了dao层编码工作
Hibernate的性能非常好,因为它是一个轻量级框架。映射的灵活性很出色。它支持很多关系型数据库,从一对一到多对多的各种复杂关系hibernate-release-5.0.7.Final下载地址:
http://sourceforge.net/projects/hibernate/files/hibernate-orm/5.0.7.Final/hibernate-release-5.0.7.Final.zip/download
2.Hibernate常用的配置文件
2.1.log4j配置
a.导入日志jar包(注意:Hibernate开发包中只是提供了一个日志接口的包slf4j,并没有提供日志的具体实现,因此,需要额外下载slf4j和log4j的开发包)
b.把log4j.properties文件拷贝到src目录下就OK。// log4j.properties文件
### direct log messages to stdout ###log4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target=System.errlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n### direct messages to file mylog.log ###log4j.appender.file=org.apache.log4j.FileAppenderlog4j.appender.file.File=d:\\mylog.loglog4j.appender.file.layout=org.apache.log4j.PatternLayoutlog4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n### set log levels - for more verbose logging change 'info' to 'debug' ###log4j.rootLogger=info, stdout
// 测试
public class TestLog4j { //创建日志记录对象 private Logger logger = Logger.getLogger(TestLog4j.class); @Test public void testLog(){ System.out.println("sysout打印日志..."); logger.info("log4j打印的日志..."); }}
- 2.2.配置文件的提示
- 如果能上网,提示是默认就有的。
- 如果不能上网,编写配置文件是没有提示的,需要自己来配置
先复制http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd –> window –> preferences –> 搜索xml –> 选择xml catalog –> 点击add –> 选择URI –> 粘贴复制的地址 –> 选择location,选择本地的DTD的路径- Configuration类似
- 2.3Hibernate映射配置文件
映射文件,即Customer.hbm.xml的配置文件
< class>标签 – 用来将类与数据库表建立映射关系
* name – 类的全路径
* table – 表名.(类名与表名一致,那么table属性也可以省略)
* catalog – 数据库的名称,基本上都会省略不写
< id>标签 -- 用来将类中的属性与表中的主键建立映射,id标签就是用来配置主键的。 * name -- 类中属性名 * column -- 表中的字段名.(如果类中的属性名与表中的字段名一致,那么column可以省略.) * length -- 字段的程度,如果数据库已经创建好了,那么length可以不写。如果没有创建好,生成表结构时,length最好指定。< property> -- 用来将类中的普通属性与表中的字段建立映射. * name -- 类中属性名 * column -- 表中的字段名.(如果类中的属性名与表中的字段名一致,那么column可以省略.) * length -- 数据长度 * type -- 数据类型(一般都不需要编写,如果写需要按着规则来编写) * Hibernate的数据类型 type="string" * Java的数据类型 type="java.lang.String" * 数据库字段的数据类型 <column name="name" sql-type="varchar"/>
- 2.4.Hibernate核心配置文件(默认:hibernate.cfg.xml )
核心配置文件的两种方式(了解)
1. 第一种方式是属性文件的形式,即properties的配置文件
hibernate.properties
hibernate.connection.driver_class=com.mysql.jdbc.Driver
缺点: 不能加载映射的配置文件,需要手动编写代码去加载,效率低
2. 第二种方式是XML文件的形式,开发基本都会选择这种方式
* hibernate.cfg.xml
* com.mysql.jdbc.Driver
* 优点: 格式比较清晰、编写有提示、 可以在该配置文件中加载映射的配置文件(最主要的)
关于hibernate.cfg.xml的配置文件方式
* 必须有的配置
a. 数据库连接信息:
hibernate.connection.driver_class – 连接数据库驱动程序
hibernate.connection.url – 连接数据库URL
hibernate.connection.username – 数据库用户名
hibernate.connection.password – 数据库密码
b.方言:
hibernate.dialect – 操作数据库方言
* 可选的配置
* hibernate.show_sql – 显示SQL
* hibernate.format_sql – 格式化SQL
* hibernate.hbm2ddl.auto – 通过映射转成DDL语句
* create – 每次都会创建一个新的表.
* create-drop – 每次都会创建一个新的表,当执行结束之后,将创建的这个表删除.
* update – 如果有表,使用原来的表.没有表,创建一个新的表.同时更新表结构.
* validate – 如果有表,使用原来的表.同时校验映射文件与表中字段是否一致如果不一致就会报错
* 加载映射
* 如果XML方式:< mapping resource=”cn/asce/domain/Customer.hbm.xml” />
- 2.5Hibernate框架整合C3P0连接池
- 先导入C3P0的jar包(3个jar包),在hibernate-release-5.0.7.Final\lib\optional目录下
- 在hibernate.cfg.xml的配置文件中编写配置
<!-- hibernate框架整合C3P0连接池 --> <!-- 1. 先导入C3P0的jar包(3个jar包),在hibernate-release-5.0.7.Final\lib\optional目录下 2. 在hibernate.cfg.xml的配置文件中编写配置 --> <!-- C3P0的供应商 --> <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> <!-- 最小连接 --> <property name="hibernate.c3p0.min_size">10</property> <!-- 最大连接 --> <property name="hibernate.c3p0.max_size">200</property> <!-- 连接超时 单位:秒 --> <property name="hibernate.c3p0.timeout">5000</property>
//Customer.hbm.xml—>跟实体类一个级别
<?xml version="1.0" encoding="UTF-8"?><!-- 在XML中引入DTD约束 --><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"><!-- Hibernate 映射配置文件(ORM映射配置文件)--><hibernate-mapping> <!-- 1.catalog:指定操作的数据库,若指定了值,则操作的数据库以这个为准,(hibernate.cfg.xml中的url的数据库不会生效) 2.name:类的全路径名 --> <class name="cn.asce.domain.Customer" table="cst_customer" catalog="mysql_day03"> <!-- id标签用来配置主键 --> <id name="cust_id" column="cust_id"> <!-- 主键增长机制 --> <generator class="native" ></generator> </id> <property name="cust_name" column="cust_name"></property> <property name="cust_user_id" column="cust_user_id"></property> <property name="cust_create_id" column="cust_create_id"></property> <property name="cust_source" column="cust_source"></property> <property name="cust_industry" column="cust_industry"></property> <property name="cust_level" column="cust_level"></property> <property name="cust_linkman" column="cust_linkman"></property> <property name="cust_phone" column="cust_phone"></property> <property name="cust_mobile" column="cust_mobile"></property> <property name="abc" column="abc"></property> </class></hibernate-mapping>
//hibernate.cfg.xml—>放在src下
<?xml version="1.0" encoding="UTF-8"?><!-- 在XML中引入DTD约束 --><!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:///myasce</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">foxlink</property> <!-- 操作数据库方言 --> <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> <!-- 自动建表 --> <!-- create-drop: 在程序运行时,(创建session工厂的时候)会自动建表,在程序停止时(关闭sessionFactory时),表删除 1.drop table if exists cst_customer 2.create table cst_customer 3.执行sql 4.drop table if exists cst_customer create: 在程序运行时,如果表不存在,自动建表,如果存在,则不进行任何操作(mysql会先删除再创建) 1.drop table if exists cst_customer 2.create table cst_customer 3.执行sql update: 在程序运行时,如果表不存在,自动建表,如果表存在,则检查表和类的结构是否一致,如果不一致,则更新表结构.(推荐) 1. validate: 在程序运行时,如果表结构和类不一致,则报错!(表中没有相应的字段,则报错,表中有冗余字段,不报错) --> <property name="hibernate.hbm2ddl.auto">update</property> <!-- hibernate框架整合C3P0连接池 --> <!-- 1. 先导入C3P0的jar包(3个jar包),在hibernate-release-5.0.7.Final\lib\optional目录下 2. 在hibernate.cfg.xml的配置文件中编写配置 --> <!-- C3P0的供应商 --> <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> <!-- 最小连接 --> <property name="hibernate.c3p0.min_size">10</property> <!-- 最大连接 --> <property name="hibernate.c3p0.max_size">200</property> <!-- 连接超时 单位:秒 --> <property name="hibernate.c3p0.timeout">5000</property> <!-- 加载映射 (包名+文件名)--> <mapping resource="cn/asce/domain/Customer.hbm.xml" /> </session-factory></hibernate-configuration>
3.Hibernate常用的接口和类
1.Configuration类
Configuration类
- Configuration对象用于配置并且启动Hibernate。
- Hibernate应用通过该对象来获得对象-关系映射文件中的元数据,以及动态配置Hibernate的属性,然后创建SessionFactory对象。
- 简单一句话:加载Hibernate的配置文件,可以获取SessionFactory对象
Configuration类的其他应用(了解)
- 加载配置文件的种类,Hibernate支持xml和properties类型的配置文件,在开发中基本都使用XML配置文件的方式。
- 如果采用的是properties的配置文件,那么通过Configuration configuration = new Configuration();就可以加载配置文件
- 但是需要自己手动加载映射文件
- 例如:config.addResource(“cn/asce/domain/Customer.hbm.xml”);
- 如果采用的XML的配置文件,通过Configuration configuration = new Configuration().configure();加载配置文件
2.SessionFactory接口
- 是工厂类,是生成Session对象的工厂类
- SessionFactory类的特点
- 由Configuration通过加载配置文件创建该对象。
- SessionFactory对象中保存了当前的数据库配置信息和所有映射关系以及预定义的SQL语句。同时,SessionFactory还负责维护Hibernate的二级缓存。
- 预定义SQL语句
- 使用Configuration类创建了SessionFactory对象是,已经在SessionFacotry对象中缓存了一些SQL语句
- 常见的SQL语句是增删改查(通过主键来查询)
- 这样做的目的是效率更高
- 一个SessionFactory实例对应一个数据库,应用从该对象中获得Session实例。
- SessionFactory是线程安全的,意味着它的一个实例可以被应用的多个线程共享。
- SessionFactory是重量级的,意味着不能随意创建或销毁它的实例。如果只访问一个数据库,只需要创建一个SessionFactory实例,且在应用初始化的时候完成。
- SessionFactory需要一个较大的缓存,用来存放预定义的SQL语句及实体的映射信息。另外可以配置一个缓存插件,这个插件被称之为Hibernate的二级缓存,被多线程所共享
- 总结
- 一般应用使用一个SessionFactory,最好是应用启动时就完成初始化
3.Session接口
- 概述
- Session是在Hibernate中使用最频繁的接口。也被称之为持久化管理器。它提供了和持久化有关的操作,比如添加、修改、删除、加载和查询实体对象
- Session 是应用程序与数据库之间交互操作的一个单线程对象,是 Hibernate 运作的中心
- Session是线程不安全的
- 所有持久化对象必须在 session 的管理下才可以进行持久化操作
- Session 对象有一个一级缓存,显式执行 flush 之前,所有的持久化操作的数据都缓存在 session 对象处
- 持久化类与 Session 关联起来后就具有了持久化的能力
- 特点
- 不是线程安全的。应避免多个线程使用同一个Session实例
- Session是轻量级的,它的创建和销毁不会消耗太多的资源。应为每次客户请求分配独立的Session实例
- Session有一个缓存,被称之为Hibernate的一级缓存。每个Session实例都有自己的缓存
- 常用的方法
- save(obj) – 保存数据
- get(Class,id) – 通过主键查询该条记录
- delete(obj) – 删除数据
- update(obj) – 修改数据
- saveOrUpdate(obj) – 保存或者修改
- createQuery(String hql) – 查询所有的数据
//get
这里写代码片
//load
这里写代码片
//delete
这里写代码片
//update
这里写代码片
//createQuery
这里写代码片
4.Transaction接口
1.Transaction是事务的接口
2.常用的方法
* commit() – 提交事务
* rollback() – 回滚事务
3.特点
* Hibernate框架默认情况下事务不自动提交.需要手动提交事务
* 如果没有开启事务,那么每个Session的操作,都相当于一个独立的事务
4.HibernateUtils
package cn.asce.utils;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.cfg.Configuration;public class HibernateUtils { //session 对象不安全,应避免多线程使用同一个Session实例 private static final Configuration CONFIG; private static final SessionFactory FACTORY; static { // 1.加载hibernate.cfg.xml配置文件 CONFIG = new Configuration().configure(); // 2.获取SessionFactory对象--->类似连接池 FACTORY = CONFIG.buildSessionFactory(); } public static Session openSession() { //3.返回Session对象 return FACTORY.openSession(); }}
- Hibernate01
- Hibernate01
- Day38-Hibernate01
- 框架之Hibernate01
- hibernate01 环境搭建
- Hibernate01(无表关联的单项N-1)
- hibernate01 和JDBC的优缺点、配置文件、加载流程、自动生成、对象的状态
- SSH与SSM学习之hibernate01——介绍与环境搭建
- 动手实现并开源IDEOnline——代码高亮【富文本编辑框】
- Spring Boot实战学习笔记5
- iOS GCD中如何控制最大并发数
- 为什么模板不支持分离编译?
- 如何自己写一个公用的NPM包
- Hibernate01
- MySQL复制中因服务器ID重复报错(Last_IO_Errno: 1593)
- 基于C语言sprintf函数的深入理解
- kafka系列之集群部署使用(二)
- python---名片管理(并对名片进行增、删、改、查、功能的实现)
- www.wonderhowto.com 黑客 科技 信息类网站
- 201412-3 集合竞价
- SpringMVC拦截器(资源和权限管理)
- JQuery 实现 图片滑动收起与隐藏