欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Entity Framework Core更新時(shí)間映射

 更新時(shí)間:2022年03月25日 10:37:51   作者:.NET開發(fā)菜鳥  
這篇文章介紹了Entity Framework Core更新時(shí)間映射的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

時(shí)間字段

在真實(shí)的開發(fā)中,為了跟蹤數(shù)據(jù)的變化,一般會(huì)在數(shù)據(jù)表里面有CreatedTime和UpdatedTime兩列。CreatedTime表示創(chuàng)建時(shí)間,新增一條數(shù)據(jù)的時(shí)候,會(huì)更新CreatedTime列的值。UpdatedTime表示更新時(shí)間,更新數(shù)據(jù)的同時(shí)也會(huì)更新UpdatedTime列的值,這時(shí)候就需要對(duì)應(yīng)的映射來(lái)配置。我們修改Blog類,增加這兩個(gè)時(shí)間字段:

using System;

namespace EFCore.Model
{
    public  class Blog
    {
        public int Id { get; set; }
        public string Name { get; set; }

        /// <summary>
        /// 創(chuàng)建時(shí)間
        /// </summary>
        public DateTime CreatedTime { get; set; }

        /// <summary>
        /// 添加時(shí)間
        /// </summary>
        public DateTime UpdatedTime { get; set; }
    }
}

這時(shí)不做任何配置,使用遷移的方式生成數(shù)據(jù)庫(kù),查看數(shù)據(jù)庫(kù)表結(jié)構(gòu):

可以看到數(shù)據(jù)庫(kù)里面生成的是datetime2類型的,datetime2的精度非常高。但是一般情況下不使用datetime2高精度的,使用datetime就可以了,這時(shí)候就需要我們自己做映射來(lái)配置生成datetime類型。

修改數(shù)據(jù)上下文類,增加時(shí)間字段的映射配置,代碼如下:

using EFCore.Model;
using Microsoft.EntityFrameworkCore;

namespace EFCore.Data
{
    /// <summary>
    /// 數(shù)據(jù)上下文
    /// </summary>
    public class EFDbContext : DbContext
    {
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder.UseSqlServer("Data Source=.;Initial Catalog=EFTest;User ID=sa;Password=123456;");
        }

        public DbSet<Blog> Blogs { get; set; }

        /// <summary>
        /// 重寫OnModelCreating方法,配置映射
        /// </summary>
        /// <param name="modelBuilder"></param>
        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            // 配置表名映射
            modelBuilder.Entity<Blog>().ToTable("Blog");
            // 將表名長(zhǎng)度設(shè)置為250會(huì)報(bào)錯(cuò),表名最大長(zhǎng)度限制為128
            //var tableName = string.Join("", Enumerable.Repeat("t", 250).ToArray());
            //modelBuilder.Entity<Blog>().ToTable(tableName);

            modelBuilder.Entity<Blog>(p =>
            {
                // 配置CreatedTime字段
                p.Property(t => t.CreatedTime)
                // 設(shè)置列的類型是DATETIME
                 .HasColumnType("DATETIME")
                 // 設(shè)置列的默認(rèn)值
                 .HasDefaultValueSql("GETDATE()");

                // 配置UpdatedTime字段
                p.Property(t => t.UpdatedTime)
                // 設(shè)置列的類型是DATETIME
                .HasColumnType("DATETIME")
                // 設(shè)置列的默認(rèn)值
                .HasDefaultValueSql("GETDATE()");
            });

            base.OnModelCreating(modelBuilder);
        }

    }
}

在使用數(shù)據(jù)遷移的方式生成數(shù)據(jù)庫(kù)表,然后查看列的數(shù)據(jù)類型:

這時(shí)候時(shí)間列的數(shù)據(jù)類型就是datetime類型了。在代碼里面給時(shí)間字段設(shè)置了默認(rèn)值,我們添加一條種子數(shù)據(jù),然后新增到數(shù)據(jù)庫(kù),看看會(huì)不會(huì)自動(dòng)生成默認(rèn)值:

從截圖中可以看出:新增數(shù)據(jù)的時(shí)候,CreatedTime和UpdatedTime會(huì)自動(dòng)賦當(dāng)前時(shí)間的值。在修改剛才添加的種子數(shù)據(jù),看看UdpatedTime列的值會(huì)不會(huì)更新:

可以看到:Name列的值已經(jīng)發(fā)生修改,但是UpdatedTime列的值卻沒(méi)有更新。但是我們想要的效果是數(shù)據(jù)更新的時(shí)候,UpdatedTime列的值也隨之更新,該怎么辦呢?有兩種方式解決這個(gè)問(wèn)題。

1、使用計(jì)算列

這種方式是對(duì)UpdatedTime字段設(shè)置使用計(jì)算列,代碼如下:

using EFCore.Model;
using Microsoft.EntityFrameworkCore;

namespace EFCore.Data
{
    /// <summary>
    /// 數(shù)據(jù)上下文
    /// </summary>
    public class EFDbContext : DbContext
    {
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder.UseSqlServer("Data Source=.;Initial Catalog=EFTest;User ID=sa;Password=123456;");
        }

        public DbSet<Blog> Blogs { get; set; }

        /// <summary>
        /// 重寫OnModelCreating方法,配置映射
        /// </summary>
        /// <param name="modelBuilder"></param>
        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            // 配置表名映射
            modelBuilder.Entity<Blog>().ToTable("Blog");
            // 將表名長(zhǎng)度設(shè)置為250會(huì)報(bào)錯(cuò),表名最大長(zhǎng)度限制為128
            //var tableName = string.Join("", Enumerable.Repeat("t", 250).ToArray());
            //modelBuilder.Entity<Blog>().ToTable(tableName);

            modelBuilder.Entity<Blog>(p =>
            {
                // 配置CreatedTime字段
                p.Property(t => t.CreatedTime)
                // 設(shè)置列的類型是DATETIME
                 .HasColumnType("DATETIME")
                 // 設(shè)置列的默認(rèn)值
                 .HasDefaultValueSql("GETDATE()");

                //// 配置UpdatedTime字段
                //p.Property(t => t.UpdatedTime)
                //// 設(shè)置列的類型是DATETIME
                //.HasColumnType("DATETIME")
                //// 設(shè)置列的默認(rèn)值
                //.HasDefaultValueSql("GETDATE()");

                // 配置UpdatedTime字段
                p.Property(t => t.UpdatedTime)
                // 設(shè)置列的類型是DATETIME
                .HasColumnType("DATETIME")
                // 設(shè)置UpdatedTime字段使用計(jì)算列
                .HasComputedColumnSql("GETDATE()");
            });

            // 添加一條種子數(shù)據(jù)
            modelBuilder.Entity<Blog>().HasData(
                new Blog() 
                {
                    Id=1,
                  Name="ef core 3.1.2"
                });
            base.OnModelCreating(modelBuilder);
        }

    }
}

然后刪除數(shù)據(jù)庫(kù),從新開始生成數(shù)據(jù)庫(kù)、新增數(shù)據(jù)、修改數(shù)據(jù)這三步,我們先看新增數(shù)據(jù)后的結(jié)果:

可以看到,CreatedTime和UpdatedTime這時(shí)會(huì)有誤差,但是誤差是秒以內(nèi)可以接受的。我們?cè)诳葱薷暮蟮慕Y(jié)果:

這時(shí)就會(huì)發(fā)現(xiàn):UpdatedTime列的值就會(huì)發(fā)生改變了。也會(huì)發(fā)現(xiàn),UpdatedTime列的數(shù)據(jù)類型是計(jì)算:

2、重寫SaveChanges方法

還有一種方式是重寫SaveChanges()方法。

我們首先在實(shí)體類庫(kù)里面定義一個(gè)IUpdatedable接口:

using System;

namespace EFCore.Model
{
    public  interface IUpdatedable
    {
        DateTime UpdatedTime { get; set; }
    }
}

然后Blog類繼承自這個(gè)接口:

using System;

namespace EFCore.Model
{
    public  class Blog:IUpdatedable
    {
        public int Id { get; set; }
        public string Name { get; set; }

        /// <summary>
        /// 創(chuàng)建時(shí)間
        /// </summary>
        public DateTime CreatedTime { get; set; }

        /// <summary>
        /// 添加時(shí)間
        /// </summary>
        public DateTime UpdatedTime { get; set; }
    }
}

然后在數(shù)據(jù)上下文類里面重寫SaveChanges方法:

public override int SaveChanges()
{
    var entries = ChangeTracker.Entries().ToList();
    var updateEntries = entries.Where(e => (e.Entity is IUpdatedable)
    && e.State == EntityState.Modified).ToList();

    updateEntries.ForEach(e => 
    {
        ((IUpdatedable)e.Entity).UpdatedTime = DateTime.Now;
    });
    return base.SaveChanges();
}

同時(shí)修改UpdatedTime字段不是計(jì)算列,賦默認(rèn)值:

// 配置UpdatedTime字段
p.Property(t => t.UpdatedTime)
// 設(shè)置列的類型是DATETIME
.HasColumnType("DATETIME")
// 設(shè)置列的默認(rèn)值
.HasDefaultValueSql("GETDATE()");

這種方式就不能使用數(shù)據(jù)遷移了,要在代碼里面調(diào)用SaveChanges方法才可以實(shí)現(xiàn):

using EFCore.Data;
using EFCore.Model;
using System;

namespace EFCore.Con
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Hello World!");
            // 實(shí)例化數(shù)據(jù)上下文對(duì)象
            EFDbContext dbContext = new EFDbContext();
            // 生成數(shù)據(jù)庫(kù)
            bool tfTrue = dbContext.Database.EnsureCreated();
            if (tfTrue)
            {
                Console.WriteLine("數(shù)據(jù)庫(kù)創(chuàng)建成功!");
            }
            else
            {
                Console.WriteLine("數(shù)據(jù)庫(kù)創(chuàng)建失敗!");
            }

            // 查詢Id為1的數(shù)據(jù)
            var blog = dbContext.Blogs.Find(1);
            // 更改表名稱
            blog.Name = "entity framework core 3.1.21212";
            dbContext.SaveChanges();
            Console.ReadKey();
        }
    }
}

數(shù)據(jù)庫(kù)效果:

這樣也完成了更新。

到此這篇關(guān)于Entity Framework Core更新時(shí)間映射的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論