jpa多对多

package com.demo.beans;


import java.util.List;
import java.util.Set;


import javax.persistence.CascadeType;
import javax.persistence.ElementCollection;
import javax.persistence.Entity;
import javax.persistence.EntityListeners;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.OneToMany;
import javax.persistence.OneToOne;




@Entity
@EntityListeners(MyMonitor.class)
public class Employee {
    @Id
    private int employeeId;




 private String employeeName;

 
 @ElementCollection
 private Set<String> nickName;
 
@OneToMany(mappedBy="employee", cascade=CascadeType.ALL)
 private List<Phone> phones;


public int getEmployeeId() {
    return employeeId;
}


public void setEmployeeId(int employeeId) {
    this.employeeId = employeeId;
}



@ManyToMany(cascade=CascadeType.ALL)
   @JoinTable(
   joinColumns={@JoinColumn(name="employeeId")},
   inverseJoinColumns={@JoinColumn(name="projectId")}
   )
   private List<Project> projects;


@OneToOne(cascade=CascadeType.ALL)
 @JoinColumn(name="AddressId")
 private Address address;


public Address getAddress() {
 return address;
 }


public void setAddress(Address address) {
 this.address = address;
 }



public Set<String> getNickName() {
    return nickName;
}


public void setNickName(Set<String> nickName) {
    this.nickName = nickName;
}


public String getEmployeeName() {
 return employeeName;
 }



public void setEmployeeName(String employeeName) {
 this.employeeName = employeeName;
 }


public List<Project> getProjects() {
    return projects;
}


public void setProjects(List<Project> projects) {
    this.projects = projects;
}


public List getPhones() {
 return phones;
 }


public void setPhones(List phones) {
 this.phones = phones;
 }


}


package com.demo.beans;


import java.util.List;


import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.ManyToMany;


@Entity(name="project")
public class Project {
 @Id
 private int projectId;


 private String projectName;


 @ManyToMany(mappedBy="projects",cascade=CascadeType.ALL)
 private List<Employee> employees;


public int getProjectId() {
 return projectId;
 }


public void setProjectId(int projectId) {
 this.projectId = projectId;
 }


public String getProjectName() {
 return projectName;
 }


public void setProjectName(String projectName) {
 this.projectName = projectName;
 }


public List<Employee> getEmployees() {
 return employees;
 }


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


测试

Project project = new Project();
        project.setProjectId(1);
        project.setProjectName("Project");


 List<Project> projects = new ArrayList<Project>();


        // add the project into the list
        projects.add(project);
//        projects.add(globalProject);
//        projects.add(localProject);


        Employee employee = new Employee();
        
        
        employee.setEmployeeName("Test Bai");
        // Set the project into employee
        employee.setProjects(projects);
        userRepository.addEmployee(employee);
                

保存后的数据库中的表记录如下:

mysql> select * from employee;
+------------+--------------+-----------+
| employeeId | employeeName | AddressId |
+------------+--------------+-----------+
|          0 | Test Bai     |      NULL |
+------------+--------------+-----------+


mysql> select * from project;
+-----------+-------------+
| projectId | projectName |
+-----------+-------------+
|         1 | Project     |
+-----------+-------------+
1 row in set (0.00 sec)


mysql> select * from employee_project;
+------------+-----------+
| employeeId | projectId |
+------------+-----------+
|          0 |         1 |
+------------+-----------+
1 row in set (0.00 sec)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值