如何使用java spring框架将多个行从Web表单插入到数据库中

时间:2011-11-10 11:24:58

标签: java spring-mvc

我是Java Spring Framework的新手,我的新项目有一个要求。

使用Spring框架,我有一个带set和get方法的POJO类。 我也有中级java服务和Web类。我使用<form>标签从jsp映射到bean类,并能够使用单个对象执行所有操作。

但我的问题是如何为多个对象(记录)做同样的工作。

简单来说: 如何使用jsp页面中的输入数据一次将7行(记录)插入数据库表中。如何从我的jsp页面接受输入参数并创建7个对应7行的对象,然后在点击提交按钮时插入它们?

请为此提供一些指导。

1 个答案:

答案 0 :(得分:8)

我可以通过让另一个POJO作为容器来实现这一点,并在其中列出您的POJO。

这看起来像这样:

public class PojoForm {
    private List<Pojo> pojos;
    public List<Pojo> getPojos() {
        return pojos;
    }
    public void setPojos(List<Pojo> pojos) {
        this.pojos = pojos;
    }
}

然后在控制器中,使用此容器而不是实际的pojo作为模型属性。

@ModelAttribute("pojoForm")
public PojoForm populatePojos() {
    // Don't forget to initialize the pojos list or else it won't work
    PojoForm pojoForm = new PojoForm();
    List<Pojo> pojos = new ArrayList<Pojo>();
    for(int i=0; i<2; i++) {
        pojos.add(new Pojo());
    }
    pojoForm.setPojos(pojos);
    return pojoForm;
}

@RequestMapping(method=RequestMethod.POST)
public String saveForm(@ModelAttribute("pojoForm") PojoForm pojoForm) {
    for(Pojo pojo : pojoForm.getPojos()) {
       service.save(pojo);
    }
    return "theview.jsp";
}

然后视图应该是这样的:

<form:form commandName="pojoForm" method="POST">
    <!-- Pojo 1 -->
    <form:input path="pojos[0].a" />
    <form:input path="pojos[0].b" />
    <form:input path="pojos[0].c" />
    <!-- Pojo 2 -->
    <form:input path="pojos[1].a" />
    <form:input path="pojos[1].b" />
    <form:input path="pojos[1].c" />
</form:form>

a,b和c是Pojo类的属性。

您也可以直接在列表中循环:

<form:form commandName="pojoForm" method="POST">
    <c:forEach items="${pojoForm.pojos}" varStatus="i">
        <form:input path="pojos[${i.index}].a" />
        <form:input path="pojos[${i.index}].b" />
        <form:input path="pojos[${i.index}].c" />
    </c:forEach>
</form:form>