Spring MVC:保存添加到表单中的值以供以后加载

时间:2019-03-10 19:07:59

标签: spring spring-mvc spring-data

我有一个ParticipantsController.java,它可以添加/删除/编辑参与者名称。

import java.util.ArrayList;
import java.util.List;

import javax.validation.Valid;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.WebDataBinder;
import org.springframework.web.bind.annotation.InitBinder;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;

import questForTheBest.domain.Participants;

@Controller
public class ParticipantsController {

@InitBinder("participant") // Validator for participant model
protected void initBinder(WebDataBinder binder) {
        binder.addValidators(new ParticipantsValidator());
}

List<Participants> participantList = new ArrayList<>(); // create a list of participants

@RequestMapping("/participants") // Participants page
public String testing(Model model) {
    model.addAttribute("participantList", participantList);
    return "forms/ParticipantMaster";
}

@RequestMapping(value = "/participantDetail", method = RequestMethod.GET) // Shows participants
public String participantDetail(@ModelAttribute("participant") Participants participant, @RequestParam(value="participantId", required=false, defaultValue="-1") int participantId) {

    if (participantId >= 1) { // Shows participants with an id greater than or equal to 1

        Participants p2 = participantList.stream().filter(p -> (p.getId() == participantId)).findAny().get(); // gets participants
        participant.setId(p2.getId()); // sets participants id
        participant.setName(p2.getName()); // sets participants name
    } else {

        participant.setId(Participants.lastId); // otherwise create a new participant id
        Participants.lastId++; // increment last id
    }
    return "forms/ParticipantDetail";
}   

@RequestMapping(value = "/addParticipant", method = RequestMethod.POST) // Adding participants page
public String addParticipant(@Valid @ModelAttribute("participant") Participants participant,BindingResult result, Model model) {


    if (result.hasErrors()) { // validation
        return "forms/ParticipantDetail";
    }
    else {


    participantList.removeIf(p -> (p.getId() == participant.getId()));
    participantList.add(participant); // add participants


    model.addAttribute("participantList", participantList);
    return "forms/ParticipantMaster";
    }
}   

@RequestMapping(value = "/deleteParticipant", method = RequestMethod.GET) // Deleting participants
public String deleteParticipant(@RequestParam(value="participantId", required=false, defaultValue="-1") int participantId, Model model) {

    participantList.removeIf(p -> (p.getId() == participantId)); // removes the participant with id
    model.addAttribute("participantList", participantList);
    return "forms/ParticipantMaster";
}



}

我希望能够:每次在表单中输入名称列表时,我都希望在按下“保存当前名称”按钮时将其保存,以便以后可以将它们再次加载到另一页上可以从下拉框中选择,然后单击“加载”按钮。

整个应用程序是排行榜,因此我希望能够保存相同的参与者,例如,以便在学校的某个班级需要使用排行榜时可以加载它。

这是否需要使用数据库,或者是否需要使用数据库。

谢谢。

1 个答案:

答案 0 :(得分:0)

当然,由于您的用例是内存(RAM)在计算机重新启动或崩溃时被刷新/重置,因此您将需要数据库将排行榜数据永久存储在固态设备上(SSD存储)。您可以使用内存中的数据结构在数据库层上方的内存层或分布式缓存中,在您的实现或redis中分别使用一个列表,以使您的应用程序高效地提供读取服务。

您的应用程序中必须具有数据库访问对象(DAO)层,用于执行与数据库相关的操作。

请参考此链接以了解如何在Spring Boot中实现DAO层

https://www.baeldung.com/jsf-spring-boot-controller-service-dao

希望这会有所帮助!