hibernate中一个实体类映射多个表的方法

写hibernate大作业过程中,出现了一个实体类中的数据要写到多个数据库表中的问题,以前MVC下解决问题方法是使用sql语句进行直接写入,但是在Hibernate大环境下,以前不太会,查找资料后:

<?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="model.Info" table="info">
		<id name="info_id" column="info_id" type="java.lang.Integer">
			<generator class="native" />
		</id>

		<property name="info_title" column="info_title" />
		<property name="info_content" column="info_content" />
		<property name="info_date" column="info_date" />
		<property name="info_type" column="info_type" />
		<property name="info_status" column="info_status" />
		<property name="info_danshuang" column="info_danshuang" />
		<property name="info_num" column="info_num" />
		<property name="info_pnum" column="info_pnum" />

		<set name="user" table="kongzhi">
			<key column="kongzhi_info_id" />
			<many-to-many class="model.User" column="kongzhi_user_id"/>
		</set>

		<join table="xuanxiang" inverse="true">
			<key column="xuanxiang_id" on-delete="cascade" />
			<property name="xuanxiang_info_id"
				column="xuanxiang_info_id" />
			<property name="xuanxiang_content"
				column="xuanxiang_content" />
			<property name="xuanxiang_num" column="xuanxiang_num" />
			<property name="xuanxiang_pnum" column="xuanxiang_pnum" />
			<property name="xuanxiang_iid" column="xuanxiang_iid" />
		</join>
		
	</class>


</hibernate-mapping>

这是解决办法,首先用join标签是用来将实体类中的属性映射到别的表中的,然后再join标签下有inverse属性是防止别的表进行修改

然后是key中的on-delete属性:

网上解释这样的,直接抄过来:

这是数据库外键定义的一个可选项,用来设置当主键表中的被参考列的数据发生变化时,外键表中响应字段的变换规则的。update 则是主键表中被参考字段的值更新,delete是指在主键表中删除一条记录:
on update 和 on delete 后面可以跟的词语有四个
no action , set null , set default ,cascade
no action 表示 不做任何操作,
set null 表示在外键表中将相应字段设置为null
set default 表示设置为默认值
cascade 表示级联操作,就是说,如果主键表中被参考字段更新,外键表中也更新,主键表中的记录被删除,外键表中改行也相应删除

(来自:https://zhidao.baidu.com/question/113831827.html)

好了暂时够我写大作业用了嘤

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

月光如春风拂面

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值