簡體   English   中英

更新記錄在LINQ to SQL中不起作用

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM