我在将linq更新为sql实体时遇到了一些麻烦。 出于某种原因,我可以更新我的item
实体的每个字段,除名称。Linq to SQL - 未能更新
这里有两个简单的测试中,我写道:
[TestMethod]
public void TestUpdateName() {
using (var context = new SimoneDataContext()) {
Item item = context.Items.First();
if (item != null) {
item.Name = "My New Name";
context.SubmitChanges();
}
}
}
[TestMethod]
public void TestUpdateMPN() {
using (var context = new SimoneDataContext()) {
Item item = context.Items.First();
if (item != null) {
item.MPN = "My New MPN";
context.SubmitChanges();
}
}
}
不幸的是,TestUpdateName()失败,出现以下错误: System.Data.SqlClient.SqlException: Incorrect syntax near the keyword 'WHERE'..
而这里的输出SQL:
UPDATE [dbo].[Items] SET WHERE ([Id] = @p0) AND ([CategoryId] = @p1) AND ([MPN] = @p2) AND ([Height] = @p3) AND ([Width] = @p4) AND ([Weight] = @p5) AND ([Length] = @p6) AND ([AdministrativeCost] = @p7) -- @p0: Input Int (Size = 0; Prec = 0; Scale = 0) [1] -- @p1: Input Int (Size = 0; Prec = 0; Scale = 0) [1] -- @p2: Input VarChar (Size = 10; Prec = 0; Scale = 0) [My New MPN] -- @p3: Input Decimal (Size = 0; Prec = 5; Scale = 3) [30.000] -- @p4: Input Decimal (Size = 0; Prec = 5; Scale = 3) [10.000] -- @p5: Input Decimal (Size = 0; Prec = 5; Scale = 3) [40.000] -- @p6: Input Decimal (Size = 0; Prec = 5; Scale = 3) [30.000] -- @p7: Input Money (Size = 0; Prec = 19; Scale = 4) [350.0000] -- Context: SqlProvider(Sql2008) Model: AttributedMetaModel Build: 3.5.30729.4926
由于你可以看到,没有更新正在产生(SET是空的......) 我不知道为什么会发生这种情况。
而且已经预先...是的,表Item
有一个PK(Id)。 谢谢提前!
更新: 看来,错误是由覆盖GetHashcode()引起的。 这是我目前实施:
return string.Format("{0}|{1}|{2}|{3}", Name, Id, UPC, AdministrativeCost).GetHashCode();
如果修改名称和一个其他财产发生了什么?它是更新两者还是仅更新其他属性?在生成的代码中,还有名为“PropertyChanged”事件的setter?我不认为DataContext认为它是一个改变,除非事件被解雇。 – 2010-06-10 17:58:20
如果我修改名称和另一个属性,则只更改其他属性。 – 2010-06-10 18:05:58