Hibernate——基础及XML配置

1、入门

hibernate是跟数据库打交道的,一般跟数据库打交道的都不简单

原始、底层直接的一些操作、编码量比较大、费时、用框架高效

把原来一点一点实现的东西,现在给个半成品,不用在这上边发时间,把重点放在业务上,而不是底层的

DAO层   Hibernate  MyBatis  都是针对DAO 层的简化框架   增删改查操作数据库,这两个框架各有优缺点,市场都挺大的,你不都了解,也不太合适

MVC调用部分     Struts2.0   SpringMVC

            Spring

核心特点:以对象的方式实现对数据库的增删改查操作

灵魂:映射

增删改就是调方法

难点:持久化对象的状态及其转换

2、Hibernate理解

开发过程中有许多重复性的内容,能不能定义一个类我直接把类和属性给他,他帮我封装好再给我,将来需要的时候就调它,比如每次取出来结果后都得遍历,能不能定义一个类,每次需要遍历时,我就调它

半成品   按着这个引导,精力就放在具体细节上   项目维护,代码重用方便

帮忙完成底层功能   银行要求安全 速度快  可能就不受框架约束

分层会延迟速度  各种方法调用都会延迟 ,性能会拖延

一提到持久化就是跟数据库挂钩

3、

持久化:程序数据在瞬时状态和持久状态间转换的过程

    比如听一首歌,下载在磁盘上,但当我听的时候,这首歌的数据是在cpu上的,cpu是瞬时的掉电即失,磁盘是持久的

持久化的两种方式:

a、序列化

啥叫序列化?

把生成的对象信息持久化保存到文件中或流中,把字节流写入数据流   以二进制状态保存,实现了平台无关性

DataInputStream  DataOutStream  读写二进制文件

FileInputStream  FileOutStream      读写文本文件

BufferedReader      FileReader        字符流也可以读文本文件的

啥叫Soket(套接字)?

两台计算机通过网络通信连接,实现数据的交换

持久化图示:

内存  存用户信息                                 瞬时状态

jdbc 操作数据库  增删改查                       |  |

数据库  存一张跟内存相对应的表             持久状态

JDBC回顾:

JDBC操作数据库到底有什么缺点,才催生了这么多框架来解决这个问题?

重复性工作多

代码冗余

在dao层之前一直都是把数据封装成对象来操作的,比如add数据,只有到dao层了,只能把它给拆开,不然没法执行sql语句了

反过来查询也是一样 

优点:效率高

代码移植困难:比如数据库迁移,比如一开始数据量不大放在Mysql中,后来数据量大了,需要把数据移植到oracle中,由于两个数据库语句差异很大,以后一个页面一个页面的修改语句是很麻烦的

用jdbc时,在dao之前一直都是面向对象,以一个对象的形态在传递,到了dao层之后是用sql语句操作数据库,必须得把对象打散,等于这一部分就不是面向对象了,java讲究低耦合,但在这部分是和sql语句耦合在一起了,将来如果更换数据库,这部分就得全部重新写

现在不再直接去操作底层的jdbc的那些东西了,直接使用hibernate提供的那些方法,还是以对象形式传递,不用自己拆解了,是hibernate帮我做了拆分

缺点:分析型的,数据量大的

优点:事务型的增删改查

ORM:对象关系映射

编写程序的时候,以对象的方式处理数据

保存数据的时候,以关系型数据的方式存储的

4、Hibernate配置

a、选择需要的jar包:根目录下的 hibernate3.jar    lib下的required 、jpa(持久化的接口) 文件夹中所有的所有jar包   放到项目的lib文件下  再加个ojdbc6(oracle数据库驱动的jar包)

b、配置文件

名字必须叫hibernate.cfg.xml

在src下new  -->other-->myeclipse-->xml-->xml(basic ...)   点next  create选第一个  select选第二个  hibernate/configration DTD3.0

DTD文件时在写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>
	<property name="connection.driver_class">
		oracle.jdbc.driver.OracleDriver
	</property>
	<property name="connection.url">
		jdbc:oracle:thin:@localhost:1521:ORCL
	</property>
	<property name="connection.username">book</property>
	<property name="connection.password">ok</property>
	<!-- 描述映射文件的保存路径 -->
	<property name="dialect">
		org.hibernate.dialect.Oracle9Dialect
	</property>
	<property name="show_sql">true</property>
	<property name="format_sql">true</property>
	<mapping resource="cn/bdqn/hibernate/entity/Book.hbm.xml" />
</session-factory>
</hibernate-configuration>

几个需要注意的点:

用户会话:HttpSession

hibernate和数据库的交流:session,是hibernate核心API,甭管干什么,先拿到session再说,通过会话工厂来拿到session

运行程序时,会先读配置文件,再由configration创建会话工厂

持久化类也就是实体类   po包=entity包 = bean包

凡是实体类、数据传递、缓存都需要实现序列化,然后会生成一个版本序列,主要是用来判断你存的那个类跟这个类是不是同一个

在定义持久化类时,跟数据库一一对应,数据类型尽量写包装类,不要写值类型,因为数据库允许为空,而值类型不允许为空的,除非数据库也写not null 才可以

c、映射文件

名字必须叫 Book.hbm.xml

在项目下建个包  创建book类

选中包,再如上建个新建的xml     select选第二个  hibernate/Maping/ DTD 3.0  

<hibernate-mapping package="cn.bdqn.hibernate.entity">
	<!--上边写package的路径了,下边class就不用写全名了,直接写类名即可
    name=类名  table=表名 -->
	<class name="Book" table="Book">
		<!-- name属性名 colum列名-->
		<id name="id" column="id">
		<!-- 配置主键生成方式,手动分配 -->
			<generator class="assigned"></generator>
		</id>
		<!-- 映射普通的属性和列的对应关系 name属性名 colum列名  type 属性 java类型   -->
		<property name="title" column="title" type="java.lang.String"/>
		<!-- 使用hibernate内置的类型 别名设置type属性-->
		<property name="author" column="author" type="string"/>
		<!-- 默认地,hibernate认为属性名与列名相同,可省略colum,数据类型也可以自动判断 -->
		<property name="publisher"/>
		<property name="price"/>
		<property name="pic"/>
	
	</class>
</hibernate-mapping>

 最后再回到hibernate.cfg.xml 下  Configuration 视图下Maping --> add  选择 Book.hbm.xml  

dialect   设置方言  选择对应的数据库  oracle9/10g     因为hibernate可以根据方言自动生成增删改查语句

在properties那  add  选择show sql   value改成true   作用是把hibernate执行的sql语句向控制台输出自动 ;  再选择foramt sql  让sql语句格式化,易读 

原文地址:https://www.cnblogs.com/Angelinas/p/5394958.html