W3Cschool
恭喜您成為首批注冊用戶
獲得88經驗值獎勵
以下代碼顯示如何刪除具有級聯(lián)操作的相關實體。
下面的代碼來自PersonDaoImpl.java。
package cn.w3cschool.common; import java.util.Date; import javax.persistence.EntityManager; import javax.persistence.PersistenceContext; import org.springframework.transaction.annotation.Transactional; @Transactional public class PersonDaoImpl { public void test() { Employee emp = new Employee(); emp.setName("Tom"); emp.setId(1); Phone ph = new Phone(); ph.setEmployee(emp); ph.setNumber("1234567890"); ParkingSpace ps = new ParkingSpace(); ps.setEmployee(emp); ps.setLocation("Dept"); emp.setParkingSpace(ps); emp.getPhones().add(ph); em.persist(emp); emp = em.find(Employee.class, 1); em.remove(emp); } @PersistenceContext private EntityManager em; }
以下代碼來自Phone.java。
package cn.w3cschool.common; import javax.persistence.Entity; import javax.persistence.Id; import javax.persistence.OneToOne; @Entity public class Phone { @Id private long id; private String number; private String type; @OneToOne Employee employee; public long getId() { return id; } public void setId(long id) { this.id = id; } public String getNumber() { return number; } public void setNumber(String phoneNo) { this.number = phoneNo; } public String getType() { return type; } public void setType(String phoneType) { this.type = phoneType; } public Employee getEmployee() { return employee; } public void setEmployee(Employee employee) { this.employee = employee; } public String toString() { return "Phone id: " + getId() + ", no: " + getNumber() + ", type: " + getType(); } }
以下代碼來自Employee.java。
package cn.w3cschool.common; import java.util.ArrayList; import java.util.Collection; import javax.persistence.CascadeType; import javax.persistence.Entity; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToMany; import javax.persistence.OneToOne; @Entity public class Employee { @Id private int id; private String name; @OneToOne(cascade={CascadeType.PERSIST, CascadeType.REMOVE}) @JoinColumn(name="PSPACE_ID") ParkingSpace parkingSpace; @OneToMany(cascade={CascadeType.PERSIST, CascadeType.REMOVE}, mappedBy="employee") Collection<Phone> phones; public Employee() { phones = new ArrayList<Phone>(); } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public Collection<Phone> getPhones() { return phones; } public void setPhones(Collection<Phone> phones) { this.phones = phones; } public void setName(String name) { this.name = name; } public ParkingSpace getParkingSpace() { return parkingSpace; } public void setParkingSpace(ParkingSpace parkingSpace) { this.parkingSpace = parkingSpace; } public String toString() { return "Employee id: " + getId() + " name: " + getName() + " with " + getParkingSpace(); } }
下面的代碼來自ParkingSpace.java。
package cn.w3cschool.common; import javax.persistence.Entity; import javax.persistence.Id; import javax.persistence.OneToOne; import javax.persistence.Table; @Entity @Table(name="PARKING_SPACE") public class ParkingSpace { @Id private int id; private int lot; private String location; @OneToOne(mappedBy="parkingSpace") private Employee employee; public int getId() { return id; } public void setId(int id) { this.id = id; } public int getLot() { return lot; } public void setLot(int lot) { this.lot = lot; } public String getLocation() { return location; } public void setLocation(String deptName) { this.location = deptName; } public Employee getEmployee() { return employee; } public void setEmployee(Employee employee) { this.employee = employee; } public String toString() { return "ParkingSpace id: " + getId() + " lot: " + getLot() + ", location: " + getLocation(); } }下載 Remove_With_Relationships_Cascade.zip
以下是數(shù)據庫轉儲。
Table Name: EMPLOYEE Table Name: PARKING_SPACE Table Name: PHONE
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: