Hibernate 需要知道怎样去加载(load)和存储(store)持久化类的对象。这正是 Hibernate 映
射文件发挥作用的地方。映射文件告诉 Hibernate 它应该访问数据库(database)里面的哪个表
(table)及应该使用表里面的哪些字段(column)。
一个映射文件的基本结构看起来像这样:
如果需要看DTD的配置文件可以到hibernate3.jar文件下的org.hibernate包下面有个hibernate-mapping-3.0.dtd和hibernate-configuration-3.0.dtd文件就是这里的约束
在 hibernate-mapping 标签(tag)之间, 含有一个 class 元素。所有的持久化实体类(再次声
明,或许接下来会有依赖类,就是那些次要的实体)都需要一个这样的映射,来把类对象映射到
SQL 数据库里的表:
<?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="org.hibernate.tutorial.domain">
<!--这里Event是类名,上面的package的路径就是这个类名的包,EVENTS则是对应的表名-->
<class name="Event" table="EVENTS">
<!--这里id 标签的name属性是对应的类的一个属性,column是对应的表的主键名-->
<id name="id" column="EVENT_ID">
<!--generator 元素指定标识符的生成策略(也就是标识符值是怎么产生的) native(全局性唯一) increment(自增)-->
<generator class="native"> </generator>
</id>
<!--这里的写法很多,第一种是将表和类型写在一起,其他的没有写的时候hibernate会自动使用缺省的配置-->
<property name="date" type="timestamp" column="EVENT_DATE"/>
<property name="title"/>
<!--这种写法之名了数据类型,将表的字段单独拿出来成一个标签, 因为表还具有自己的一些属性-->
<property name="name" type="java.lang.String">
<column name="name" not-null="true"/>
</property>
</class>
</hibernate-mapping
>
为了保存 Hibernate 的配置,我们可以使用一个简单的 hibernate.properties 文件,或者一个
稍微复杂的 hibernate.cfg.xml,甚至可以完全使用程序来配置 Hibernate。多数用户更喜欢使用
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">com.mysql.jdbc.Driver</property>
<!-- 配置DATE的地址 -->
<property name="connection.url">jdbc:mysql://127.0.0.1:3306/test</property>
<!-- 配置数据库的用户名 -->
<property name="connection.username">root</property>
<!-- 配置数据库的密码 -->
<property name="connection.password">123456</property>
<!-- 输出SQL执行语句 -->
<property name="show_sql">true</property>
<!-- 确定方言 -->
<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>
<!-- 能够生成DDL建表语句, -->
<property name="hbm2ddl.auto">update</property>
<!-- 读取映射的文件 -->
<mapping resource="com/sun/domain/Employee.hbm.xml"/>
<mapping resource="com/sun/domain/Content.hbm.xml"/>
</session-factory>
</hibernate-configuration>