加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc-3 – 实体框架4.1自动日期

发布时间:2020-12-16 03:33:47 所属栏目:asp.Net 来源:网络整理
导读:我是Entity Framework(和asp.net mvc 3)的新手,这是我第一次使用EF4.1代码时的第一次体验. 我的问题很简单:当我通过模型生成一个新的数据库表我想做 创建新行时,自动将当前日期时间添加到字段. 每次更新字段时自动更新字段. 实际上,变量看起来像: [Display
我是Entity Framework(和asp.net mvc 3)的新手,这是我第一次使用EF4.1代码时的第一次体验.

我的问题很简单:当我通过模型生成一个新的数据库表我想做

>创建新行时,自动将当前日期时间添加到字段.
>每次更新字段时自动更新字段.

实际上,变量看起来像:

[DisplayName("Data Modifica")]
 [DataType(DataType.DateTime)]
 [DisplayFormat(DataFormatString = "{0:d}")]
 public DateTime DataModifica { get; set; }

我想我可以写一些关于datacontext的“OnModelCreating”事件,但我太新了已经掌握了这个:)

有人可以帮忙吗?

提前致谢,
V.

解决方法

这与模型的创建无关. “模型”是类和数据库之间映射的描述. OnModelCreating用于修改映射定义,而不是修改数据.它与实体实例本身的数据无关.

如果要自动修改,可以覆盖SaveChanges:

public override int SaveChanges()
{
     DateTime now = DateTime.Now;
     foreach (var entity in ChangeTracker.Entries<YourEntityType>()
                                         .Where(e => e.State == EntityState.Added || e.State == EntityState.Modified)
                                         .Select(e => e.Entity))
     {
          entity.DateModifica = now; // set the date
     }

     return base.SaveChanges();
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读