Hibernate基础

**

一、什么是Hibernate?

**
  Hibernate是一个轻量级的ORMapping框架
  ORMapping原理(Object Relational Mapping)

在这里插入图片描述

ORMapping基本对应规则

  • 1:类跟表相对应
  • 2:类的属性跟表的字段相对应
  • 3:类的实例与表中具体的一条记录相对应
  • 4:一个类可以对应多个表,一个表也可以对应对个类
  • 5:DB中的表可以没有主键,但是Object中必须设置主键字段
  • 6:DB中表与表之间的关系(如:外键)映射成为Object之间的关系
  • 7:Object中属性的个数和名称可以和表中定义的字段个数和名称不一样

ORMapping的基本实现方式
使用JDBC,用SQL来操作数据库,只是看动态生成还是人工写代码来实现。
大家想想,我们实现过ORMapping吗?

在这里插入图片描述

**

二、Hibernate能干什么:

**

Hibernate主要用来实现Java对象和表之间的映射,除此之外还提供还提供数据查询和获取数据的方法,可以大幅度减少开发时人工使用SQL和JDBC处理数据的时间。

Hibernate的目标是对于开发者通常的数据持久化相关的编程任务,解放其中的95%。对于以数据为中心的程序来说,它们往往只在数据库中使用存储过程来实现商业逻辑,Hibernate可能不是最好的解决方案;对于那些在基于Java的中间层应用中,它们实现面向对象的业务模型和商业逻辑的应用,Hibernate是最有用的。

Hibernate可以帮助你消除或者包装那些针对特定厂商的SQL代码,并且帮你把结果集从表格式的表示形式转换到一系列的对象去。

在这里插入图片描述

一个非常简要的Hibernate体系结构的高层概要图

在这里插入图片描述

Hibernate运行时体系结构
“最小”的体系结构方案,要求应用程序提供自己的 JDBC 连接并管理自己的事务。这种方案使用了Hibernate API 的最小子集.

在这里插入图片描述

“全面解决”的体系结构方案,将应用层从底层的JDBC/JTA API中抽象出来,而让Hibernate来处理这些细节。

在这里插入图片描述

**

三、Hibernate中的对象

**
SessionFactory (org.hibernate.SessionFactory)
针对单个数据库映射关系经过编译后的内存镜像,是线程安全的(不可变)。 它是生成的工厂,本身要用到。
Session (org.hibernate.Session)
表示应用程序与持久储存层之间交互操作的一个单线程对象,此对象生存期很短,隐藏了连接,也是的工厂。
Transaction (org.hibernate.Transaction)
应用程序用来指定原子操作单元范围的对象,它是单线程的,生命周期很短。它通过抽象将应用从底层具体的、以及事务隔离开。
ConnectionProvider (org.hibernate.connection.ConnectionProvider)
生成连接的工厂(有连接池的作用)。它通过抽象将应用从底层的或隔离开。仅供开发者扩展/实现用,并不暴露给应用程序使用。
TransactionFactory (org.hibernate.TransactionFactory)
生成对象实例的工厂。仅供开发者扩展/实现用,并不暴露给应用程序使用。

示例如下:
数据库表:Student.sql

CREATE TABLE "STUDENT" 
(    
    "STUNO" VARCHAR2(20), 
    "STUNAME" VARCHAR2(20), 
    "STUPASS" VARCHAR2(20), 
    "STUSEX" VARCHAR2(2), 
    "MOBILE" VARCHAR2(20), 
    "EMAIL" VARCHAR2(20), 
    "ADDRESS" VARCHAR2(50), 
    "STUAGE" NUMBER
)

配置文件: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>
        <!-- 数据库URL -->
        <property name="connection.url">jdbc:oracle:thin:@localhost:1521:orcl</property>
        <!-- 数据库用户名 -->
        <property name="connection.username">zhengcheng</property>
        <!-- 数据库密码 -->
        <property name="connection.password">123123</property>
        <!-- JDBC驱动 -->
        <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
        
        <!-- 每个数据库都有对应的Dialect以匹配其平台特性 -->
        <property name="dialect">org.hibernate.dialect.Oracle10gDialect</property>
        <!-- 指定当前session范围和上下文 -->
        <property name="current_session_context_class">thread</property>
        <!-- 指定运行期生成的SQL输出到日志以供调试 -->
        <property name="show_sql">true</property>
        <!-- 是否格式化sql -->
        <property name="format_sql">true</property>
        
        <!-- 映射文件 -->
        <mapping resource="Student.hbm.xml" />    
    </session-factory>
</hibernate-configuration>

1:与被描述的类同名 ,如:Student.hbm.xml
2:存放位置与所描述类存放在同一文件夹下
3:主要有如下四部分配置 :
(1)类和表的映射
(2)主键的映射
(3)类的属性和DB中字段的映射
(4)关系的映射
4:配置的时候可以到hibernate发行包里面找个例子,比如可以用“\project\hibernate-core\src\test\java\org\hibernate\test\cid”下面的Customer.hbm.xml作例子
映射文件:Student.hbm.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值