Java-hibernate的映射文件

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>

 

  

 

 

  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值