Hibernate一对多和多对多的映射和核心文件的配置

一对多

  • 创建实体
    一的一方创建set集合,多的一方创建一的一方的对象
  • 映射文件
  1. 一的一方
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<class name="com.sssddd.hibernate.domain.Customer" table="cst_customer">
		<!-- 建立OID与主键映射 -->
		<id name="cust_id" column="cust_id">
			<generator class="native"/>
		</id>
		<!-- 建立普通属性与数据库表字段映射 -->
		<property name="cust_name" column="cust_name" />
		<property name="cust_source" column="cust_source"/>
		<property name="cust_industry" column="cust_industry"/>
		<property name="cust_level" column="cust_level"/>
		<property name="cust_phone" column="cust_phone"/>
		<property name="cust_mobile" column="cust_mobile"/>
		<!-- 配置一对多的映射:放置的多的一方的集合 -->
		<!-- 
			set标签 :
				* name	:多的一方的对象集合的属性名称。
				* cascade:级联
				* inverse:放弃外键维护权。
		-->
		<set name="linkMans" cascade="save-update" inverse="true">
			<!--
				 key标签
					* column:多的一方的外键的名称。
			 -->
			<key column="lkm_cust_id"/>
			<!-- 
				one-to-many标签
					* class	:多的一方的类的全路径
			 -->
			<one-to-many class="com.sssddd.hibernate.domain.LinkMan"/>
		</set>
	</class>
</hibernate-mapping>
  1. 多的一方
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<class name="com.sssddd.hibernate.domain.LinkMan" table="cst_linkman">
		<!-- 建立OID与主键映射 -->
		<id name="lkm_id" column="lkm_id">
			<generator class="native"/>
		</id>
		<!-- 建立普通属性与表字段映射 -->
		<property name="lkm_name"/>
		<property name="lkm_gender"/>
		<property name="lkm_phone"/>
		<property name="lkm_mobile"/>
		<property name="lkm_email"/>
		<property name="lkm_qq"/>
		<property name="lkm_position"/>
		<property name="lkm_memo"/>
		<!-- 配置多对一的关系:放置的是一的一方的对象 -->
		<!-- 
			many-to-one标签
				* name		:一的一方的对象的属性名称。
				* class		:一的一方的类的全路径。
				* column	:在多的一方的表的外键的名称。
		 -->
		<many-to-one name="customer" class="com.sssddd.hibernate.domain.Customer" column="lkm_cust_id"/>
	</class>
</hibernate-mapping>
  • 配置核心文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
	<session-factory>
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="hibernate.connection.url">jdbc:mysql:///hibernate</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password">root</property>
		<!-- 配置hibernate的方言 -->
		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
		
		
		<!--打印SQL语句  -->
		<property name="hibernate.show_sql">true</property>
		<!--格式化SQL语句  -->
		<property name="hibernate.format_sql">true</property>
		<!-- 自动创建表 -->
		<property name="hibernate.hbm2ddl.auto">updata</property>
		
		<!-- 配置C3P0连接池 -->
		<property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
		<!--在连接池中可用的数据库连接的最少数目 -->
		<property name="c3p0.min_size">5</property>
		<!--在连接池中所有数据库连接的最大数目  -->
		<property name="c3p0.max_size">20</property>
		<!--设定数据库连接的过期时间,以秒为单位,
		如果连接池中的某个数据库连接处于空闲状态的时间超过了timeout时间,就会从连接池中清除 -->
		<property name="c3p0.timeout">120</property>
		 <!--每3000秒检查所有连接池中的空闲连接 以秒为单位-->
		<property name="c3p0.idle_test_period">3000</property>
		
		<!-- 配置事务的隔离级别 -->
		<property name="hibernate.connection.isolation">4</property>
		 <!-- 配置session绑定本地线程 -->
 		<property name="hibernate.current_session_context_class">thread</property>
		 
		 <!-- 引入映射 -->
		<mapping resource="com/sssddd/hibernate/domain/Customer.hbm.xml"/>
		<mapping resource="com/sssddd/hibernate/domain/LinkMan.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

多对多关系配置

  • 创建三个表,用户表,角色表和中间表
  • 创建实体
    用户类中设置角色类的set集合
    角色类中设置用户类的set集合
  • 创建映射
    角色的映射文件中:
			<!-- 与用户的多对多的映射关系 -->
			<!-- 
				set标签
					* name		:对方的集合的属性名称。
					* table		:多对多的关系需要使用中间表,放的是中间表的名称。
			 -->
    		<set name="users" table="sys_user_role" cascade="save-update,delete" inverse="true" >
	    		<!-- 
					key标签:
						* column	:当前的对象对应中间表的外键的名称。
				 -->	
    			<key column="rele_id" />
    			<!-- 
				many-to-many标签:
					* class		:对方的类的全路径
					* column	:对方的对象在中间表中的外键的名称。
			 	-->	
    			<many-to-many class="com.sssddd.hibernate.domain.User" column="user_id" />
    		</set>

用户的映射文件中:

<set name="roles" table="sys_user_role"  cascade="save-update,delete" >
				<key  column="user_id" />
				<many-to-many class="com.sssddd.hibernate.domain.Role" column="role_id" />
			</set>
  • 多对多建立双向关系,一定有一方放弃外键维护,一般为被动方放弃

猜你喜欢

转载自blog.csdn.net/weixin_43875648/article/details/88839643
今日推荐