Hibernate提供了从xml生成数据表的数据功能。

示例:

Studnet.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.mzsx.model.Student" table="student" catalog="struts">
<id name="id" type="java.lang.String">
<column name="studentid" />
<generator class="uuid" />
</id>
<property name="studentname" type="java.lang.String">
<column name="studentname" length="50" not-null="true" />
</property>
<one-to-one name="cardid" class="com.mzsx.model.Card" cascade="all"  ></one-to-one>
</class>
</hibernate-mapping>

Card.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.mzsx.model.Card" table="card" catalog="struts">
<id name="id" type="java.lang.String">
<column name="cardid" />
<generator class="foreign">
<param name="property">studentid</param>
</generator>
</id>
<property name="cardname" type="java.lang.String">
<column name="cardname" length="50" not-null="true" />
</property>
<one-to-one name="studentid" class="com.mzsx.model.Student" ></one-to-one>
</class>
</hibernate-mapping>

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">
<!-- Generated by MyEclipse Hibernate Tools.                   -->
<hibernate-configuration>
<session-factory>
<property name="hbm2ddl.auto">update</property>
<!-- Mysql -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="connection.url">jdbc:mysql://localhost:3306/struts</property>
<property name="connection.username">root</property>
<property name="connection.password">admin</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="myeclipse.connection.profile">MySQL connection</property>
<!-- Oracle -->
<!-- <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<property name="connection.username">0804</property>
<property name="connection.password">0804</property>
<property name="connection.url">jdbc:oracle:thin:@192.168.0.200:1521:orcl</property> -->
<!-- 配置JDBC里batch的大小 -->
<property name="jdbc.fetch_size">50</property>
<property name="jdbc.batch_size">25</property>
<!-- 配置事务实现方式 -->
<property name="transaction.factory_class">org.hibernate.transaction.JDBCTransactionFactory</property>
<!-- 配置线程安全的session -->
<property name="current_session_context_class">thread</property>
<property name="javax.persistence.validation.mode">none</property>
<!-- 显示SQL -->
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<!-- 配置连接池 -->
<property name="c3p0.max_size">2</property>
<property name="c3p0.min_size">2</property>
<property name="c3p0.timeout">5000</property>
<property name="c3p0.max_statements">100</property>
<property name="c3p0.idle_test_period">3000</property>
<property name="c3p0.acquire_increment">2</property>
<property name="c3p0.validate">false</property>
<!-- 指定hibernate管理的映射文件 -->
<mapping resource="com/mzsx/model/Card.hbm.xml" />
<mapping resource="com/mzsx/model/Studnet.hbm.xml" />
<!--
<mapping resource="com/mzsx/model/Blog.hbm.xml" />
<mapping resource="com/mzsx/model/Comment.hbm.xml" />
<mapping resource="com/mzsx/model/Category.hbm.xml" />
<mapping resource="com/mzsx/model/Link.hbm.xml" />
<mapping resource="com/mzsx/model/Admin.hbm.xml" /> -->
</session-factory>
</hibernate-configuration>

TableTest:

package com.mzsx.test;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
public class TableTest {
public static void main(String[] args) {
Configuration configuration=new Configuration().configure();
SchemaExport sc=new SchemaExport(configuration);
sc.create(true, false);
}
}
执行的结果:
drop table if exists struts.card
drop table if exists struts.student
create table struts.card (
cardid varchar(255) not null,
cardname varchar(50) not null,
primary key (cardid)
)
create table struts.student (
studentid varchar(255) not null,
studentname varchar(50) not null,
primary key (studentid)
)