写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)
好了暂时够我写大作业用了嘤