![](/img/trans.png)
[英]Updating record not working in LINQ to SQL with primary key set in class
[英]Updating record not working in LINQ to SQL
我有這個序列生成查詢,它獲取當前序列並將其增加到下一個值。 但增量不是更新。 nextval始終返回1,即數據庫中的默認值
Entity | StartVal | Increment | CurVal | NextVal
----------------------------------------------------
INVOICE | 0 | 1 | 0 | 1
nextval應該是3,5,7等等
int nextVal = 0;
using (var db = new MedicStoreDataContext())
{
DAL.LINQ.Sequence seq = (from sq in db.Sequences
where sq.Entity == entity
select sq).SingleOrDefault();
if (seq != null)
{
nextVal = seq.NextVal.HasValue ? seq.NextVal.Value : 0;
seq.NextVal = nextVal + 2;
db.SubmitChanges();
}
}
我是否遺失了一些東西?
更新:答案:我需要設置主鍵並更新序列類字段以包含主鍵
通常這是因為它沒有找到表的唯一標識符(或主鍵)。
在您的數據描述中,您確定表格是否正確選取了唯一的項目? - 當我第一次嘗試這個時雖然我有一個唯一的密鑰等,但是c#中的表描述沒有將它標記為唯一,所以linq悄悄沒有像我預期的那樣更新它,沒有錯誤沒有警告。 一旦我在c#中更正了數據表,一切都進展順利。
這不是正確的行為嗎? 如果CurVal為0,你不期望nextVal為1嗎? 我可能在這里遺漏了一些東西,但似乎你有點過分復雜了。 不是你想要做的基本上
using (var db = new MedicStoreDataContext())
{
DAL.LINQ.Sequence seq = (from sq in db.Sequences
where sq.Entity == entity
select sq).SingleOrDefault();
if (seq != null)
{
seq.CurVal += seq.Increment;
db.SubmitChanges();
}
}
我不明白為什么你需要整個nextVal位。 如果我錯了,請隨時糾正我。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.