![](/img/trans.png)
[英]How do I join more than one files, in a Linq (C#) where one of the joins is a left join
[英]More than one record is updated EF-Linq C#
我有下表:
我有几个数组,如果数据匹配以减少其数量,我将在其中滚动:
//DISMINUYE CANTIDAD DE CASILLER
public void disminuyeCasiller(string[] codParte, string [] rolls, double[] cantResta)
{
int size = codParte.Length;
for(int i = 0; i < size; i++)
{
string parte = codParte[i];
string rol = rolls[i];
double valorRes = cantResta[i];
using(var ctx=new ModelContext())
{
Casiller updateRollo = ctx.Casillers.Where(x => x.cod_parte == parte && x.rollo == rol).First();
double newValue = updateRollo.cantidad - valorRes;
updateRollo.cantidad = newValue;
ctx.SaveChanges();
}
}
}
根据这个代码做什么,这是第一个知道的安排是什么尺寸(所有的阵列将具有相同的大小),创建for
并得到量如果rollo
和cod_parte
比赛,这一数额你在这个恢复情况300
将减去到达cantResta
(例如100.50
,一旦在该位置分配了减法,则保存更改并在必要时重复,直到一切都好为止。
我正在传递这些数据:
codparte[]=new array{"11155"};
rollos[]=new array{"RT0102"};
cantRest[]=new array{100.50};
//Size and data can be different -only a example
在结束cantidad
与rollo RT0102
在表中我应该留下这样的: 199.50
,问题是,同时更新记录,它看起来是这样的:
如果未选择此行,为什么还要更新RT0103
? 我这句话做错了什么? (将来可能会出现问题,因为许多rollos
具有相同的信息)
屏幕断点
只有cod_parte是主键
这就是问题。
一个主键必须是唯一的,但是在您的情况下,您有多个具有相同cod_parte
记录。 因此,它甚至都不是关键,更不用说主要了。
当您调用SaveChanges()
,EF将生成一条带有WHERE子句的SQL语句,该子句包含主键,并且不包含其他任何内容,并假定主键将完全标识一条记录。 这种假设是错误的,因为您的“主键”实际上并不是键。
对于这个表,你至少需要的复合主键cod_parte
和rollo
,或者像罗伯特指出,一个真正的合成主键。
另请参阅如何在EF中指定复合键 。
请检查您的传递数据,如果仅传递codParte=111555,rolls=RT0102,cantRest=100.50
,则不会更新RT0103
。
例如:
public class Test{
public static void Main(){
disminuyeCasiller(new[] { "111555"}, new[] { "RT0102"}, new[] {100.50});
}
public static void disminuyeCasiller(string[] codParte, string[] rolls, double[] cantResta)
{
int size = codParte.Length;
for (int i = 0; i < size; i++)
{
string parte = codParte[i];
string rol = rolls[i];
double valorRes = cantResta[i];
Console.WriteLine($"parte {parte}/rol {rol}/valorRes {valorRes}"); //Result:parte 111555/rol RT0102/valorRes 100.5
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.