hibernate中多对一双向关联关系主要是对应数据库中的多对一的关系,其实这是一种非常常见的关系,这里以生产商(factory)和产品(product)为例进行讲解。
【以下是配置hibernate多对一双向关联关系的详细步骤与代码,本人是初学者,这可能对初学者来说比较容易入手,也希望能让更多像我一样的初学者更快理解和入手。】
使用开发工具:
IDE:eclipse
数据库:MySql
【以下使用代码下载地址:http://download.youkuaiyun.com/detail/liu_005/9163211】
1、建表:(方法一)
这里我们用sql语句建表(下面有另外的方法,可以不使用sql语句建表),当然建立数据库的语句就不在这里写了,你自己随便建个数据库就行(记得等下在hibernate.cfg.xml中修改成对应数据库就行),sql语句如下:
生厂商表
DROP TABLE IF EXISTS `tab_factory`;
CREATE TABLE `tab_factory` (
`factoryId` int(11) NOT NULL AUTO_INCREMENT,
`factoryName` varchar(45) DEFAULT NULL,
PRIMARY KEY (`factoryId`)
) ENGINE=InnoDB AUTO_INCREMENT=22 DEFAULT CHARSET=latin1;
产品表
DROP TABLE IF EXISTS `tab_product`;
CREATE TABLE `tab_product` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(45) NOT NULL,
`price` double NOT NULL,
`factory_id` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=33 DEFAULT CHARSET=latin1;
2、数据表建完后,我们开始编辑配置文件:
(1)编写hibernate全局配置文件
<?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="hibernate.cache.use_second_level_cache">true</property>
<!-- 指定缓存产品提供商 -->
<property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
<!-- 数据库驱动 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 数据库连接的URL -->
<property name="connection.url">jdbc:mysql://localhost:3306/test</property>
<!-- 数据库连接用户名 -->
<property name="connection.username">root</property>
<!-- 数据库连接密码 -->
<property name="connection.password">123</property>
<!-- Hibernate方言 -->