java - 如何将学生添加到学生组

标签 java mysql spring hibernate jsp

我不知道如何将学生添加到学生组,我的代码如下所示:

型号:

@Entity
@Table(name = "groups")
public class Groups extends BaseEntitity {


    @Column(name = "group_name", nullable = false, length = 20)
    private String GroupName;

学生:

@Entity
@Table(name = "student")
public class Student extends BaseEntitity{



@Column(name = "name", nullable = false, length = 35)
private String name;

@Column(name = "last_name", nullable = false, length = 20)
private String last_name;

@Column(name = "birth_date", nullable = false)
private String birth_date;

@Column(name = "city", nullable = false, length = 30)
private String city;

学生团体:

@Entity
@Table(name="student_group")
public class StudentGroup extends  BaseEntitity {
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "id_student", nullable = false)
private Student student;
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "id_group", nullable = false)
private Group group;

我想通过单击学生旁边的按钮将学生添加到组中,转到包含组的页面,然后单击所选组旁边的按钮将之前选定的学生添加到该组中,如下所示:

<td>${student.birthDate}</td>
                        <td>${student.city}</td>

                        <td> <a href="${goToGroupURL}" class="btn btn-primary">Add Group</a></td>

<c:forEach items="${groupList}" var="group">
                <tr>
                    <td>${group.id}</td>
                    <td>${group.GroupName}</td>
                    <td> <a href="${addGroupURL}/${group.id}" class="btn btn-primary">Add Group</a></td>
                </tr>
            </c:forEach>

服务:

@Service
public class AddGroupServiceImpl implements AddGroupService {
@Autowired
private StudentGroupDAO studentGroupDAO;

@Autowired
private GroupDAO groupDAO;

@Override
@Transactional
public void addStudentToGroup(Student student, Group Group) {
    StudentGRoup studentGroup = new StudentGroup(student, group);

    studentGroupDAO.save(studentGroup);
    groupDAO.save(group);

Controller :

  @RequestMapping(value = "/add-student/group/{groupId}")
public String createStudentGroup(@PathVariable Long groupId, Lond studentId, Principal principal, RedirectAttributes redirectAttributes) {



    Group group = groupDao.findOne(groupId);
    Student student = studentDao.findOne(studentId);



    addGroupService.addStudentToGroup(student, group);

学生组DAO:

@Repository public interface StudentGroupDAO extends JpaRepository<StudentGroup, Long> { }

我不知道如何在 Controller 和jsp中执行此操作,有人可以帮忙吗?

最佳答案

总的来说,这个概念看起来不错。问题在于您将分离的实体传递给持久性提供程序进行保存。

尝试将 ID 传递给事务服务并在那里执行查询:

@Override
@Transactional
public void addStudentToGroup(Integer studentId, Integer groupId) {
    Group group = groupDao.findOne(groupId);
    Student student = studentDao.findOne(studentId);

    StudentGrupa studentGrupa = new StudentGrupa(student, grupy);

    studentGroupDAO.save(studentGroup);
    groupDAO.save(group);
}

不确定 studentGroupDAO.save 内部发生了什么,但现在您将保存托管实体。

关于java - 如何将学生添加到学生组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44072610/

相关文章:

java - 当我编写函数时,如何阻止 Visual Studio Code 自动填充参数名称?

java - 当给予大量资源来执行简单计算时,Spark 工作线程 'KILLED exitStatus 143'

java - 如何注释自定义 Spring Boot 自定义存储库?

java - 如何在 spring 中为运行时动态创建的对象注入(inject)依赖?

php过滤mysql多个复选框

java - Controller 不支持 JAVA。 Spring MVC

java - 如果返回值在同步块(synchronized block)之外声明/返回,方法是否是线程安全的?

java - 有没有更简洁的方法来实现这一点?

asp.net - 无法在asp.net中执行没有参数的mysql存储过程

Php:在执行插入查询时检索一个表的主键并存储到另一个表中。