`
暗黑小菠萝
  • 浏览: 45967 次
  • 性别: Icon_minigender_2
  • 来自: 大连
社区版块
存档分类
最新评论

Hibernate简介与搭建(一)

阅读更多
一、Hibernate简介

1.Hibernate:底层依然是通过JDBC实现的,它是对JDBC进行了轻量级的封装。
Hibernate主要用来实现Java对象和表之间的映射,除此之外还提供还提供数据查询和获取数据的方法,可以大幅度减少开发时人工使用SQL和JDBC处理数据的时间。
Hibernate可以帮助你消除或者包装那些针对特定厂商的SQL代码,并且帮你把结果集从表格式的形式转换到一系列的对象中去。
Hibernate是java中一款开源的ORM框架。

2.持久化:将程序数据在持久状态和瞬时状态间的转换的一种机制
持久化应用:将内存中的对象存储在关系型数据库中/磁盘文件/XML数据文件中
瞬时状态:保存在内存中的数据,在程序退出后数据消失。

3.ORM(Object relational mapping)对象关系数据库映射技术
把对象模型表示的对象映射到基于SQL的关系型数据库结构中的技术。
是一种面向对象的编程方法,使用ORM方法可以避免写底层的sql语句,保证了java的跨平台、扩展、可维护。

4.其他主流的持久化层框架
MyBatis  Toplink  EJB(重量级的,本身是JavaEE规范)等等

5.Hibernate优缺点
①面向对象的思想来操作数据库
②可移植性:Hibernate做了持久化封装,所写代码具有可复用性。
③轻量级框架:不需要继承任何类,不需要实现任何接口。
缺点
①使用数据库特定的优化语句时候,不适合使用Hibernate
②Hibernate在批量数据处理时有弱势,不适合批量修改删除等操作,也是ORM框架的弱点
③效率比JDBC略差

二、Hibernate开发框架搭建
1.去官网下载相应的文档:
http://sourceforge.net/projects/hibernate/files/
  下载相应的jdbc driver
mySql:http://dev.mysql.com/downloads/connector/j/3.0.html
oracle:http://www.oracle.com/technetwork/database/enterprise-edition/jdbc-112010-090769.html
导入下载的jar包到工程中


2.在src目录下创建hibernate.cfg.xml文件,完成基本配置
先对其中几个重要属性进行说明:
属性名称作用
hibernate.connection.driver_classcom.mysql.jdbc.Driver等数据库驱动名
hibernate.connection.url*连接数据库名称
hibernate.connection.username*数据库登陆用户名
hibernate.connection.password*数据库登陆密码
hibernate.show_sqltrue/false打印出sql语句
hibernate.format_sqltrue/false格式化sql语句
hbm2ddl.autocreate/update/create-drop/validate生成表结构策略
hibernate.default_schema*生成表结构时默认添加前缀
hibernate.dialectorg.hibernate.dialect.MySQLDialect等方言

注:以上的属性名称均可以去掉hibernate.
<!DOCTYPE hibernate-configuration PUBLIC  
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 

<hibernate-configuration> 
	<session-factory>
		<!-- oracle数据库驱动 -->
		<property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
		<!-- oracle想要连接的数据库名称 -->
		<property name="connection.url">jdbc:oracle:thin:@127.0.0.1:1521:orcl</property>
		<!-- 数据库的登陆用户名 -->
		<property name="connection.username">SUNYQ</property>
		<!-- 数据库的登陆密码 -->
		<property name="connection.password">123456</property>
		<!-- 方言:为每一种数据库提供适配器,方便转换 -->
		<property name="hibernate.dialect">org.hibernate.dialect.OracleDialect</property>
		<property name="show_sql">true</property>
		<property name="format_sql">true</property>
		<property name="hbm2ddl.auto">create</property> 
		<mapping resource="Students.hbm.xml"/>	
	</session-factory>    
</hibernate-configuration>    


3.创建实体类Students.java
实体类的创建必须遵循JavaBeans的设计原则:
①公有类
②提供公有的不带参数的构造方法
③属性私有
④get/set封装
package com.iteye.sunyq.hibernate;

public class Students {
	public Students() {

	}

	private int sid;

	private String sname;

	public int getSid() {
		return sid;
	}

	public void setSid(int sid) {
		this.sid = sid;
	}

	public String getSname() {
		return sname;
	}

	public void setSname(String sname) {
		this.sname = sname;
	}

}


4.创建对象/关系映射文件Students.hbm.xml
hbm配置中一些说明:
<hibernate-mapping中
属性名称作用
schema         *                       模式名
catalog        *                       目录名
default-cascade*                       级联风格
default-access field/property/ClassName访问策略
default-lazy   true/false              加载策略
package        *                       包名

<class中
属性名称作用
name       *类别
table      *表名
batch-size n一次抓取n条数据
where      *条件
entity-name*同一个实体类映射成多个表

<id中
属性名称作用
name  *属性名
type  *类型
column*表中字段名称
length*长度

<id中包含一个子标签是主键生成策略<generator class="native"></generator>
uuid     按照uuid策略自动生成主键
assigned 代码中手动给主键赋值
native   根据数据库底层设置生成主键
foreign  对应其他表主键
identity SqlServer自增
incrementMySQL自增
sequence Oracle自增

等等
<?xml version="1.0"?>  
<!DOCTYPE hibernate-mapping PUBLIC   
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
    
<hibernate-mapping>  
	<class name="com.iteye.sunyq.hibernate.Students" table="students">
		<id name="sid" type="integer">
			<column name="id"></column>
			<generator class="native"></generator>
		</id>
		<property name="sname" type="string">
			<column name="sname"></column>
		</property>
	</class>
</hibernate-mapping>    

对于属性中的type可以有多种填写方式,还是以表格进行总结
基本类型
Hibernate映射类型Java类型
integer/int      java.lang.Integer/int
long             java.lang.Long/long
date             java.util.Date/java.sql.Date
timestamp        java.util.Date/java.util.Timestamp
time             java.util.Date/java.sql.Time
calendar         java.util.Calendar
calendar_date    java.util.calendar

在填写type属性值时使用Hibernate类型或者java类型都可以
对象类型
Hibernate映射java            mySQLOracle标准SQL
binary       byte[]          BLOB BLOB  VARCHAR/BLOB
text         java.lang.StringTEXTCLOBCLOB
clobjava.sql.clobTEXTCLOBCLOB
BLOBjava.sql.BlobBLOBBLOBBLOB

5.将Student.hbm.xml文件加入hibernate.cfg.xml配置文件中
<mapping resource="Students.hbm.xml"/> 

6.通过Hibernate API编写访问数据库的代码
package com.iteye.sunyq.hibernate;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;

public class Test {
	
	public static void main(String[] args) {
		//创建配置对象
		Configuration config = new Configuration().configure();
		//创建服务注册对象
		ServiceRegistry service = new StandardServiceRegistryBuilder().applySettings(config.getProperties()).build();
		SessionFactory sessionFactory = config.buildSessionFactory(service);
		Session session = sessionFactory.openSession();
		Transaction transaction = session.beginTransaction();
		Students student = new Students();
		session.save(student);
		transaction.commit();
		session.close();
	}

}

Hibernate4使用ServiceRegistry服务注册对象来创建SessionFactory对象。

以上就能够完成简单的Hibernate框架的搭建了(亲测好用),但是实际的项目中可能还是有一定区别的。
  • 大小: 19.1 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics