从迭代列表中保存对象

时间:2013-10-21 22:31:39

标签: java oracle hibernate list loops

我目前正在工作'在使用java + hibernate + oracle的销售模块上...我在我的jsp中完成了我的订单表格,如下所示:

我的参数是这样做的:

ArrayList<String> idMercaderias = new ArrayList<String>();
ArrayList<String> cantidades = new ArrayList<String>();
ArrayList<String> precios = new ArrayList<String>();
for (int k = 0; k < 10; k++) {
  idMercaderias.add(request.getParameter("idMercaderia" + k));
  cantidades.add(request.getParameter("cantidad" + k));
  precios.add(request.getParameter("precio" + k));
}

我的订单详细信息有10行,所以我创建了for,我的输入是input1,input2,input3等。这些是我的对象Mercaderia的属性所以我需要设置它们,因为它们&#39;列表:

首先我要过滤第一个列表以避免重复文章:

Iterator itra = idMercaderias.listIterator();
ArrayList<String> sortedListIdMercaderias = new ArrayList<String>();
Object m;
while (itra.hasNext()) {
m = itra.next();
  if (!sortedListIdMercaderias.contains(m)) {
  sortedListIdMercaderias.add((String) m);
  }
}

现在我创建我的对象来设置所有属性:

DetallePedido detalle = new DetallePedido();

现在我做了10次循环(想到我表单中的所有行)并开始迭代每个列表以获取我的对象属性,避免空或空条目。

for (int x = 0; x < sortedListIdMercaderias.size(); x++) {
Iterator itr = idMercaderias.listIterator();
while (itr.hasNext()) {
  String mercaderia = (String) itr.next();
  if ((mercaderia != null) && (!mercaderia.equals(""))) {
    Mercaderia mercaderiaSeleccionada = new MercaderiaDAO().findById(Integer.parseInt(mercaderia));
    detalle.setMercaderia(mercaderiaSeleccionada);
    }
}

Iterator itr2 = cantidades.listIterator();
while (itr2.hasNext()) {
  String cantidad = (String) itr2.next();
  if ((cantidad != null) && (!cantidad.equals(""))) {
    int cantidadMercaderiaSeleccionada = Integer.parseInt(cantidad);
    detalle.setCantidad(cantidadMercaderiaSeleccionada);
    }
}

Iterator itr3 = precios.listIterator();
while (itr3.hasNext()) {
  String precio = (String) itr3.next();
  if ((precio != null) && (!precio.equals(""))) {
    BigDecimal precioMercaderiaSeleccionada = new BigDecimal(precio);
    detalle.setPrecioUnitario(precioMercaderiaSeleccionada);                    
    }
}

最后我只是坚持到我的数据库:

Session session = new DetallePedidoDAO().getSession();
Transaction tx = session.beginTransaction();
try {
  session.saveOrUpdate(detalle);
  tx.commit();
session.close();
} catch (HibernateException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
}
}

我不知道为什么在数据库中我只插入1行(最后一行包含有效数据)而不是全部。

任何帮助都会非常准确,这是我在大学项目中的最终测试。

2 个答案:

答案 0 :(得分:2)

你只有一个DetallePedido对象。您在各种循环中反复更改其字段值,但它仍然只是一个对象。最后你要保存它。就一次。当然,您只需在数据库中插入一行。

您可以尝试的是,而不是分别遍历Mercaderia个对象,Cantidad个对象和Precio个对象;有一个循环,每个ITER迭代创建一个新的DetallePedido对象,设置MercaderiaCantidadaPrecio,然后保存DetallePedido

答案 1 :(得分:1)

所以,按照David Wallace的线索,我对这个想法进行了一些调整,并创建了一个像这样的对象WrapperDetallePedido

public class WrapperDetallePedido {

    int idMercaderia;
    int cantidad;
    double precio;

    public int getIdMercaderia() {
        return idMercaderia;
    }
    public void setIdMercaderia(int idMercaderia) {
        this.idMercaderia = idMercaderia;
    }
    public int getCantidad() {
        return cantidad;
    }
    public void setCantidad(int cantidad) {
        this.cantidad = cantidad;
    }
    public double getPrecio() {
        return precio;
    }
    public void setPrecio(double precio) {
        this.precio = precio;
    }

}

然后在我的控制器中,我创建了一个ArrayList并设置了我的DetallePedido属性:

ArrayList<WrapperDetallePedido> listado = new ArrayList<WrapperDetallePedido>();
for (int k = 0; k < 10; k++) {
        if (!request.getParameter("idMercaderia" + k).equals("")){
            WrapperDetallePedido WDetallePedido = new WrapperDetallePedido();
            WDetallePedido.setIdMercaderia(Integer.parseInt(request.getParameter("idMercaderia" + k)));
            WDetallePedido.setCantidad(Integer.parseInt(request.getParameter("cantidad" + k)));
            WDetallePedido.setPrecio(Double.parseDouble(request.getParameter("precio" + k)));
            listado.add(WDetallePedido);
        }                   
    }

最后使用Iterator作为上一个列表,并将listado中的所有项目设置为持久存储到数据库中:

for (Iterator iterador = listado.listIterator(); iterador.hasNext();) {
    WrapperDetallePedido detalle = (WrapperDetallePedido) iterador.next();
    Mercaderia mercaderiaSeleccionada = new MercaderiaDAO().findById(detalle.getIdMercaderia());
    DetallePedido detallePedido = new DetallePedido();
    detallePedido.setMercaderia(mercaderiaSeleccionada);
    detallePedido.setCantidad(detalle.getCantidad());
    detallePedido.setPrecioUnitario(new BigDecimal(detalle.getPrecio()));
    detallePedido.setPedidos(pedidoGenerado);
    Session session1 = new DetallePedidoDAO().getSession();
    Transaction tx1 = session1.beginTransaction();
    new DetallePedidoDAO().save(detallePedido);
    try {
        session1.saveOrUpdate(detallePedido);
        tx1.commit();
        session1.close();
        } catch (HibernateException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

最后根据需要插入了所有行...谢谢!