對于兩個不同的表,在hibernate中可以設置它們的多對多關系,一對一關系或者是多對一關系。而且還有單向和雙向的問題。這些都是學hibernate必學的,這里不再重復。我只說下級聯刪除時應注意的問題,多對一單向關系到底能不能實現級聯?
假設存在兩個表:欄目(lm)表,內容(mknr)表;它們屬于多對一的關系,即欄目可以包括多個內容。則有以下方式:
欄目表對應的pojo類:Lm.java
public class Lm implements java.io.Serializable
{
//欄目id
private int id;
private String name;
private Set mknr = new HashSet();

//getter和setter方法

}
欄目表對應的映射文件:Lm.hbm.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class catalog="eteares" name="cn.edu.ujn.wsjx.model.Lm" table="lm">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="identity" />
</id>
<property name="name" type="java.lang.String">
<column length="20" name="name" />
<set name="mknr" inverse="false" cascade="all">
<key column="lmId" />
<one-to-many class="cn.edu.ujn.wsjx.model.Mknr"/>
</set>
</class>
</hibernate-mapping>
內容表對應的pojo類:Mknr.java
public class Mknr implements java.io.Serializable
{
private int id;
private String title;
private String content;
private Lm lm;
//getter和setter方法

}
內容表對應的映射文件:Mknr.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
<class name="cn.edu.ujn.wsjx.model.Mknr" table="mknr" catalog="eteares">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="identity" />
</id>
<property name="title" type="java.lang.String">
<column name="title" length="100" />
</property>
<property name="content" type="java.lang.String">
<column name="content" length="16777215" />
</property>
<many-to-one name="lm" class="cn.edu.ujn.wsjx.model.Lm" lazy="false">
<column name="lmId" />
</many-to-one>
</class>
</hibernate-mapping>
從上面的代碼可以得知,這種設置方式屬于一對多雙向關聯,為什么不設置成多對一單向關聯呢(把Lm.java中的mknr屬性去掉),之前我就是這么設置,但每當刪除lm中的記錄時,刪除就會出現外鍵參考的錯誤,這是因為mknr中有記錄外鍵到了lm表中,而刪除時因為單向關聯無法通過lm找到mknr
所以要使用級聯刪除,就要設置成雙向關聯!
假設存在兩個表:欄目(lm)表,內容(mknr)表;它們屬于多對一的關系,即欄目可以包括多個內容。則有以下方式:
欄目表對應的pojo類:Lm.java



























































從上面的代碼可以得知,這種設置方式屬于一對多雙向關聯,為什么不設置成多對一單向關聯呢(把Lm.java中的mknr屬性去掉),之前我就是這么設置,但每當刪除lm中的記錄時,刪除就會出現外鍵參考的錯誤,這是因為mknr中有記錄外鍵到了lm表中,而刪除時因為單向關聯無法通過lm找到mknr
所以要使用級聯刪除,就要設置成雙向關聯!