EF6/EFCore Code-First Timestamp SQL Server


EF 6和EF Core都包含TimeStamp數據注解特性。它只能用在實體的byte數組類型的屬性上,並且只能用在一個byte數組類型的屬性上。然后在數據庫中,創建timestamp數據類型的列,在更新語句中,EF API自動使用timestamp列,用於並發檢查。
一個實體只能有一個時間戳列,我們看看下面的圖:
enter description here
enter description here

using System.ComponentModel.DataAnnotations;

public class Student
{
    public int StudentId { get; set; }
    public string StudentName { get; set; }
    [Timestamp]
    public byte[] RowVersion { get; set; }
}

 

在上面的例子中,TimeStamp特性應用於Student實體的byte[]類型的RowVersion屬性上,所以,EF 將會給RowVersion創建一個timestamp數據類型:
enter description here

timestamp類型的列,在更新的時候,會包含在where語句中:

 
using(var context = new SchoolContext()) 
{
    var std = new Student()
    {
        StudentName = "Bill"
    };
 
    context.Students.Add(std);
    context.SaveChanges();
 
    std.StudentName = "Steve";
    context.SaveChanges();
}

 

上面的代碼,將會生成下面的語句:

 
exec sp_executesql N'UPDATE [dbo].[Students]
SET [StudentName] = @0
WHERE (([StudentId] = @1) AND ([RowVersion] = @2))
SELECT [RowVersion]
FROM [dbo].[Students]
WHERE @@ROWCOUNT > 0 AND [StudentId] = @1',N'@0 nvarchar(max) ,@1 int,@2 binary(8)',@0=N'Steve',@1=1,@2=0x00000000000007D1
go

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM