第一个Hibernate程序

这儿以一个简单的单机程序来示范Hibernate的配置与功能,在这个例子中的一些操作,实际上会使用一些自动化工具来完成,而不一定亲自手动操作设定,这儿完全手动的原因,在于让您可以知道Hibernate实际上会做哪些事情,在进行范例之前,请先确定前一个主题中的相关jar文件都已经设定在CLASSPATH中。
我们先作数据库的准备工作,在MySQL中新增一个HibernateTest数据库,并建立USER表:
代码:

CREATE TABLE USER (
user_id CHAR(32) NOT NULL PRIMARY KEY,
name VARCHAR(16) NOT NULL,
sex CHAR(1),
age INT
);



我们先撰写一个纯Java类,它表示一个数据集合,呆会我们会将之映射至数据库的表上,程序如下:
代码:

package com.xtedu.teach.hibernate.mappings;
public class User {
private String id;
private String name;
private char sex;
private int age;
public int getAge() {
return age;
}
public String getId() {
return id;
}
public String getName() {
return name;
}
public char getSex() {
return sex;
}
public void setAge(int i) {
age = i;
}
public void setId(String string) {
id = string;
}
public void setName(String string) {
name = string;
}
public void setSex(char c) {
sex = c;
}
}

 

其中id是个特殊的属性,Hibernate会使用它来作为主键识别,我们可以定义主键产生的方式,这是在XML映射文件中完成,为了告诉Hibernate对象如何映射至数据库表,我们撰写一个XML映射文件User.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>
<class name="com.xtedu.teach.hibernate.mappings.User" table="USER">
<id name="id" type="string" unsaved-value="null">
<column name="user_id" sql-type="char(32)" />
<generator class="uuid.hex"/>
</id>
<property name="name" type="string" not-null="true">
<column name="name" length="16" not-null="true"/>
</property>
<property name="sex" type="char"/>
<property name="age" type="int"/>
</class>
</hibernate-mapping>


这个XML文件定义了对象属性映射至数据库表的关系,您可以很简单的了解映射的方法,像是User对象对应至USER表,其中我们使用uuid.hex来定义主键的产生算法,UUID算法使用IP地址、JVM的启动时间、系统时间和一个计数值来产生主键。除了使用uuid.hex之外,我们还可以使用其它的方式来产生主键,像是increment等,这可以在Hibernate参考手册中找到相关数据。
<property>标签用于定义Java对象的属性,而其中的<column/>标签用于定义与数据库的对应,如果您是手工建立Java对象与数据库表,则在最简单的情况下,可以只定义<property name="sex"/>这样的方式,而由Hibernate自动判断Java对象属性与数据库表名称对应关系,在<property/>与<column/>标签上的额外设定(像是not null、sql-type等),则可以用于自动产生Java对象与数据库表的工具上。
接下来我们定义Hibernate配置文件,主要是进行SessionFactory配置,
Hibernate可以使用XML或属性文件来进行配置,我们这儿先介绍如何使用XML配置,这也是Hibernate所建议的配置方式,我们的文档名是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>
<!-- 显示实际操作数据库时的SQL -->
<property name="show_sql">true</property>
<!-- SQL方言,这儿设定的是MySQL -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- JDBC驱动程序 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- JDBC URL -->
<property name="connection.url">jdbc:mysql://127.0.0.1:3306/teach</property>
<!-- 数据库使用者 -->
<property name="connection.username">root</property>
<!-- 数据库密码 -->
<property name="connection.password">root</property>
<!-- 对象与数据库表映射文件 -->
<mapping resource="com/xtedu/teach/hibernate/mappings/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>

 

接下来我们撰写一个测试的程序,这个程序将直接以Java程序设计人员熟悉的语法方式来操作对象,而实际上也直接完成对数据库的操作,程序将会将一笔数据存入表之中:
代码:

import com.xtedu.teach.hibernate.mappings.*;
import org.hibernate.*;
import org.hibernate.cfg.*;
public class HibernateTest {
public static void main(String[] args) throws HibernateException {
SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
User user = new User();
user.setName("caterpillar");
user.setSex('M');
user.setAge(28);
Session session = sessionFactory.openSession();
Transaction tx= session.beginTransaction();
session.save(user);
tx.commit();
session.close();
sessionFactory.close ();
System.out.println("新增数据OK!请先用MySQL查看结果!");
}
}


Configuration代表了Java对象至数据库的映射设定,这个设定是从我们上面的
XML而来,接下来我们从Configuration构建SessionFactory对象,并由它来开启一个Session,它代表对象与表的一次会话操作,而Transaction则表示一组会话操作,我们只需要直接操作User对象,并进行Session与Transaction的相关操作,Hibernate就会自动完成对数据库的操作。这儿对程序先只作简单的介绍,之后再详加说明。
将所有的.java文件编译,并将两个XML文件放置在与HibernateTest相同的目录中,也就是文件位置如下:
OK!现在您可以执行HibernateTest,程序将会出现以下的讯息:
代码:

Hibernate: insert into USER (name, sex, age, user_id) values (?, ?, ?, ?)


新增数据OK!请先用MySQL查看结果!
这儿只先进行数据的存入,要查看数据存入的结果的话,请进入MySQL查看,以下是数据库存入的结果:
代码:
mysql> SELECT * FROM USER;
+----------------------------------+-------------+------+------+
| user_id | name | sex | age |
+----------------------------------+-------------+------+------+
| 297e3dbdfea6023d00fea60241000001 | caterpillar | M | 28 |
+----------------------------------+-------------+------+------+
1 rows in set (0.00 sec)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值