Hibernate源码解析

Hibernate源码解析

一、先在官网 https://sourceforge.net/projects/hibernate/ 下载最新版本的开发包
在这里插入图片描述
下载解压后
在这里插入图片描述

  • documentation存放Hibernate的相关文件与API
  • lib存放Hibernate编译和运行所依赖的jar包,其中required子目录下包含了运行Hibernate项目必须的jar包。
  • project存放Hibernate各种相关的源代码与资源,project目录下的etc目录非常重要,它里面有一些关于Hibernate的配置信息。

二、新建一个 Java Project 即可

三、导入项目所需的jar包
在这里插入图片描述
四、配置Hibernate4框架各个层

创建数据库和表

CREATE DATABASE hibernate;
USE hibernate;

DROP TABLE IF EXISTS `t_class`;
CREATE TABLE `t_class` (
  `classId` bigint(20) NOT NULL AUTO_INCREMENT,
  `className` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`classId`)
) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8;

DROP TABLE IF EXISTS `t_student`;
CREATE TABLE `t_student` (
  `stuId` bigint(20) NOT NULL AUTO_INCREMENT,
  `stuName` varchar(255) DEFAULT NULL,
  `classId` bigint(20) DEFAULT NULL,
  PRIMARY KEY (`stuId`),
  KEY `FK_frxpowmeqnmf3sflhwgq3x0ub` (`classId`),
  CONSTRAINT `FK_frxpowmeqnmf3sflhwgq3x0ub` FOREIGN KEY (`classId`) REFERENCES `t_class` (`classId`)
) ENGINE=InnoDB AUTO_INCREMENT=19 DEFAULT CHARSET=utf8;

项目结构
在这里插入图片描述
Hibernate4相关配置文件

  • hibernate.cfg.xml:它是Hibernate框架的核心配置文件。放在src目录下
  • xxx.hbm.xml:它主要是用于描述类与数据库中的表的映射关系。放在 hsx.com.model 目录下

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="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property> //hibernate为数据库名
        <property name="connection.username">root</property>
        <property name="connection.password">123456</property>  //数据库密码
       
        <!-- 方言 -->
        <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
	
        <!-- 控制台显示SQL -->
        <property name="show_sql">true</property>

        <!-- 自动更新表结构 -->
        <property name="hbm2ddl.auto">update</property>
        
     	<mapping resource="hsx/com/model/Student.hbm.xml"/>
        
        <!-- 映射到Teacher的实体@Entity -->
        <mapping class="hsx.com.model.Student"/>  
        
    </session-factory>

</hibernate-configuration>

Student.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<!-- 配置文件 -->

<hibernate-mapping package="hsx.com.model">

	<class name="Student" table="t_student"> <!-- name 实体类类名,table=数据表表名 -->
		<id name="id" column="stuId">  <!--id是数据表中主键的映射,其他字段用property;name表示实体类中的属性,column表示id映射到数据表的字段名 -->
			<generator class="native"></generator>
		</id>
		
		<property name="name" column="stuName"></property>
		
		<many-to-one name="c" column="classId" class="hsx.com.model.Class" cascade="save-update"></many-to-one>
<!-- 在<many-to-one>这端,cascade默认是"none",假如我们希望在持久化多的一端的时候,自动级联保存和更新一的一端,可把cascade设置成"save-update" -->
	</class>

</hibernate-mapping>

创建实体类
hsx.com.model.Student.java

package hsx.com.model;

public class Student {

	private long id;
	private String name;
	private Class c;

	public long getId() {
		return id;
	}

	public void setId(long id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public Class getC() {
		return c;
	}

	public void setC(Class c) {
		this.c = c;
	}

	@Override
	public String toString() {
		return "Student [id=" + id + ", name=" + name + "]";
	}

}

生成Session工厂
hsx.com.util.HibernateUtil.java

package hsx.com.util;

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

public class HibernateUtil {

	private static final SessionFactory sessionFactory = buildSessionFactory();

	private static SessionFactory buildSessionFactory() {
		/* 实例化配置文件 */
		Configuration configuration = new Configuration().configure();
		/* 实例化服务登记 */
		ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder()
				.applySettings(configuration.getProperties()).build();
		/* 获取Session工厂 */
		return configuration.buildSessionFactory(serviceRegistry);
	}

	public static SessionFactory getSessionFactory() {
		return sessionFactory;
	}

}

创建测试类
hsx.com.service.StudentTest.java

package hsx.com.service;

import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import hsx.com.model.Student;
import hsx.com.util.HibernateUtil;

/*XML版CRUD实现*/
public class StudentTest {

	private SessionFactory sessionFactory = HibernateUtil.getSessionFactory();

	public static void main(String[] args) {
		StudentTest studentTest = new StudentTest();
		studentTest.add();
		// studentTest.delete();
		// studentTest.update();
		// studentTest.getAllStudent();
	}

	private void add() {
		/* 生成一个session */
		Session session = sessionFactory.openSession();
		/* 开启事务 */
		session.beginTransaction();

		Student s = new Student();
		s.setName("周杰伦");
		session.save(s);

		/* 提交事务 */
		session.getTransaction().commit();
		/* 关闭session */
		session.close();
	}

	private void delete() {
		/* 生成一个session */
		Session session = sessionFactory.openSession();
		/* 开启事务 */
		session.beginTransaction();

		Student student = (Student) session.get(Student.class, Long.valueOf(1));
		session.delete(student);

		/* 提交事务 */
		session.getTransaction().commit();
		/* 关闭session */
		session.close();
	}

	private void update() {
		/* 生成一个session */
		Session session = sessionFactory.openSession();
		/* 开启事务 */
		session.beginTransaction();

		Student student = (Student) session.get(Student.class, Long.valueOf(2));
		student.setName("张三2");
		session.save(student);

		/* 提交事务 */
		session.getTransaction().commit();
		/* 关闭session */
		session.close();
	}

	private void getAllStudent() {
		/* 生成一个session */
		Session session = sessionFactory.openSession();
		/* 开启事务 */
		session.beginTransaction();

		String hql = "from Student";
		Query query = session.createQuery(hql);
		@SuppressWarnings("unchecked")
		List<Student> studentList = query.list();
		for (Student student : studentList) {
			System.out.println(student);
		}

		/* 提交事务 */
		session.getTransaction().commit();
		/* 关闭session */
		session.close();
	}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本下载包与书籍的实战篇紧密结合. 下载包中的程序是一个简明的示例论坛程序,按照循序渐进的原则,分为不同的步骤: 步骤1: 建立最简单的项目基础结构:Board/User/Article三个类,包含最基本的配置文件。同时,在这一步中,建立测试类,刻画项目各个类之间的契约关系。 步骤2: 对文章的种类增加“投票”类型,展示对多型的处理。 步骤3: 增加webwork实现的GUI。 加入中文支持。 步骤4: 升级到Hibernate 3。 环境说明 --------- 程序包中的程序经过测试的运行环境为: 1, Tomcat 5.0.25 2, Hibernate 2.1.7 3, Hibernate 3.0.2 4, Eclipse 3.0.1 (作为IDE) 5, ant 1.6(作为build工具) 6, java sdk 1.4.2 7, mysql 4.1 (作为后台数据库) 8, 至少250M硬盘空间(hibernate 2,3和webwork就将占据138M) 虽然在更高版本中应该可以不加修改的运行,但我们对此不加以保证。(v1.2将对Hibernate 3.0.4进行测试) 安装说明 --------- 1, 确认jdk 1.4.2已经正确安装; 2,将本程序包解压,假设目录为: x:\rs\hib-samples 3, 从hibernate的sf下载区下载2.1.7与3.0.2版本: http://sourceforge.net/project/showfiles.php?group_id=40712 4,将下载的hibernate包解压到x:\rs\hib-samples\hibernate-2.1与x:\rs\hib-samples\hibernate-3,目录结构应该为: x: + rs + hib-samples <--- 本文件包解压的目录 + forum-step1-db-first-middlegen + forum-step1-db-first-synchronizer + forum-step2 + ... + hibernate-2.1 <--- Hibernate 2.1.7解压到这里 + bin <--- 确认bin与doc目录就在解压后的hibernate-2.1目录中 + doc + ... + hibernate-3.0 <--- Hibernate 3.0.2解压到这里 + bin preference -> Java -> Build Path -> User Librarys,分别建立名为Hibernate2,hibernate3,mysql-jdbc的用户库,分别包含对应的lib文件(如hibernate2包含hibernate-2.1目录下的hibernate2.jar及其lib目录下的所有jar文件); 11, 在您的eclipse 中,导入各个目录下的.project文件,以建立工程.(工程名为step1,step2,step3,step4)。在工程的类路径配置中,使用上一步创建的用户库(step1-step3使用Hibernate2,step4使用hibernate3)。确保没有编译错误。 好了,您现在可以开始阅读代码,作一些自己的改变,看看您能得到什么结果 :) 中文处理说明 ------------ 关于中文的处理,是在step3加入的,因此在step1以及step2中,请使用英文进行实验。具体进行的处理为全程采用UTF-8编码. 1,mysql创建时,字符集必须选择UTF-8 2,在mysql jdbc连接的url中,必须指定采用utf-8 encoding。 jdbc:mysql://localhost/forum?useUnicode=true&characterEncoding=utf-8&mysqlEncoding=utf8 3,在jsp页面中,指定页面采用UTF-8编码. 假若在您的项目中,必须使用GBK编码,则在以上的各个地方,都需要把UTF-8更换为GBK方可正常使用。 版本更新 ----------- v1.2 (PLAN,TBD) * 转换到JTA * 给出一个脱离DAO模式的例子 * 给出for hibernate 3的xdoclet例子 v1.1 (2005.5.25) * 分离db目录下的build.xml * 增加了对投票的图形显示 * 修正了和webwork相关的一个中文bug v1.0 (2005.4.20) * 初始版本

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值