spring+hibernate+mysql 只能使用mysql的innodb设置外键进行级联删除吗? 5

 我来答
dszhr035ekq
2011-08-25 · TA获得超过345个赞
知道小有建树答主
回答量:923
采纳率:100%
帮助的人:587万
展开全部
CREATE TABLE SC(
Sno CHAR(8) ,
foregin key (Sno) references Student(Sno)
);

友情提示一下楼主,MySQL的外键只能在InnoDB表中使用。这个很关键,因为一般都会使用默认的MyISAM。
于金宝1
2017-05-14
知道答主
回答量:5
采纳率:0%
帮助的人:3438
展开全部
package entity;

import java.util.HashSet;
import java.util.Set;

import javax.persistence.Cacheable;
import org.hibernate.annotations.Cascade;
import org.hibernate.annotations.CascadeType;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;

import javax.persistence.OneToMany;
import javax.persistence.Table;

@Cacheable
@Table(name="DEPARTMENTS")
@Entity
public class Department {

private Integer id;
private String departmentName;
private String introduction;
private Set<Employee> employees = new HashSet<Employee>();

@GeneratedValue
@Id
public Integer getId() {
return id;
}

public void setId(Integer id) {
this.id = id;
}

public String getDepartmentName() {
return departmentName;
}

public void setDepartmentName(String departmentName) {
this.departmentName = departmentName;
}

public String getIntroduction() {
return introduction;
}

public void setIntroduction(String introduction) {
this.introduction = introduction;
}

// 与private Department department;的getter方法上的 @JoinColumn(name="DEPARTMENT_ID") 一致
@Cascade(CascadeType.DELETE)
@JoinColumn(name="DEPARTMENT_ID")
@OneToMany(fetch=FetchType.LAZY)
public Set<Employee> getEmployees() {
return employees;
}

public void setEmployees(Set<Employee> employees) {
this.employees = employees;
}

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式