MVCで倉庫管理用のアプリケーションを開発しています。在庫フィールドを増やす必要がある製品を受け取ったとき、および製品を送信するときに在庫テーブルを更新する必要があります私は在庫フィールドを割り引く必要がある、私は)新しい行を追加することですし、私が欲しいのは、行(フィールド証券のみ)添付写真Table InventarioMVCのLinqで更新フィールド
マイコントローラー[郵便]更新することです:
//CREAMOS/DECLARAMOS LA TRANSACCION
using (var transaccion = db.Database.BeginTransaction())
{
try
{
//CARGO LOS DATOS A RECEPCION
Recepcion recepcion = new Recepcion
{
Kn_CodigoProveedor = proveeid,
Kn_CodigoBodega = bodeid,
UserId = usuaid,
f_Ingreso = fingreso,
f_Factura = ffactura,
f_Guia = fguia,
n_Guia = nguia,
n_Factura = nfactura,
n_OrdenCompra = nordencompra,
};
db.Recepcions.Add(recepcion);
db.SaveChanges();
//RECUPERO EL ULTIMO ID QUE GENERO (ULTIMA RECEPCION)
ultimarecepcionid = db.Recepcions.ToList().Select(r => r.Kn_CodigoRecepcion).Max();
//CICLO QUE GUARDA CADA ELEMENTO DEL DETALLE
foreach (ProductosRecepcion item in recepcionview.ProductosList)
{
var detalle = new RecepcionDetalle()
{
Kn_CodigoRecepcion = ultimarecepcionid,
Kn_CodigoProducto = item.Kn_CodigoProducto,
Foto = item.Foto,
d_Cantidad = item.d_Cantidad,
Precio_Unitario = item.Precio_Unitario,
};
//CARGO EL OBJETO AL DETALLE
db.RecepcionDetalles.Add(detalle);
foreach (ProductosRecepcion item1 in recepcionview.ProductosList)
{
//RECUPERO ULTIMO STOCK (TABLA INVENTARIO)
UltimoStock = db.Inventarios.Where(b => b.Kn_CodigoBodega == bodeid).Where(p => p.Kn_CodigoProducto == item.Kn_CodigoProducto).ToList().Select(p => p.Stock).Max();
}
//ARMO EL OBJETO PARA ACTULIZAR MI TABLA INVENTARIO
var stock = new Inventario()
{
Kn_CodigoProducto = item.Kn_CodigoProducto,
Kn_CodigoBodega = bodeid,
Stock = (detalle.d_Cantidad + UltimoStock),
};
//GUARDO
db.Inventarios.Add(stock);
}
db.SaveChanges();
//CONFIRMAMOS EXITO DE TRANSACCION
transaccion.Commit();
}
catch (Exception ex)
{
//CONFIRMAMOS FRACASO DE TRANSACCION
transaccion.Rollback();
ViewBag.Error = "ERROR: " + ex.Message;
return View(recepcionview);
}
}
を
私の英語のために申し訳ありません、私のための任意のヘルプ?
どのような特有の問題がありますか? – Shyju