小编dcg*_*cga的帖子

EF 7为DateTime列设置初始默认值

我需要能够设置DateTime列的初始值.

当我指定"getutcdate()或DateTime.UtcNow时

entity.Property(e => e.ShipDate).DefaultValue("getutcdate()")
entity.Property(e => e.ShipDate).DefaultValue(DateTime.UtcNow)
Run Code Online (Sandbox Code Playgroud)

然后运行dnx . ef migration add InitialMigrationEF生成迁移快照:

b.Property<DateTime?>("ShipDate")
  .Required()
  .Annotation("Relational:ColumnDefaultValue", "getutcdate()")
  .Annotation("Relational:ColumnDefaultValueType", "System.String");
Run Code Online (Sandbox Code Playgroud)

当我使用DateTime.UtcNow ...

b.Property<DateTime?>("ShipDate")
  .Annotation("Relational:ColumnDefaultValue", "635754129448768827")
  .Annotation("Relational:ColumnDefaultValueType", "System.DateTime");
Run Code Online (Sandbox Code Playgroud)

和初始迁移:

ShipDate = table.Column(
  type: "datetime2", 
  nullable: false, 
  defaultValue: "getutcdate()"),
Run Code Online (Sandbox Code Playgroud)

当我使用DateTime.UtcNow ...

ShipDate = table.Column(
  type: "datetime2", 
  nullable: true, 
  defaultValue: new DateTime(2015, 8, 17, 12, 55, 44, 876, DateTimeKind.Unspecified)),
Run Code Online (Sandbox Code Playgroud)

看起来它必须工作,但是当我将数据插入表中时,列的默认值是创建时间戳的"即时".

我错过了什么吗?

另外,既然如此,如何在EF7中指定IDENTITY SEED?

谢谢

更新 生成sql脚本后,我得到两个选项:

如果使用"getutcdate()":

[ShipDate] datetime2 DEFAULT 'getutcdate()',
Run Code Online (Sandbox Code Playgroud)

由于引号不起作用

或者如果使用DateTime.utcNow:

[ShipDate] datetime2 DEFAULT '2015-08-17 12:55:44.8760000'
Run Code Online (Sandbox Code Playgroud)

这解释了我得到的静态价值.

我想我可以用这个来管理.这是一个错误还是有正确的方法吗?谢谢

c# entity-framework-core

7
推荐指数
2
解决办法
1万
查看次数

标签 统计

c# ×1

entity-framework-core ×1