Csharp/C#教程:无法在ASP.NET MVCentity framework中将值NULL插入到列中分享


无法在ASP.NET MVCentity framework中将值NULL插入到列中

尝试使用此代码时:

var model = new MasterEntities(); var customer = new Customers(); customer.Sessionid = 25641; model.Customers.Add(customer); model.SaveChanges(); 

我明白了:

{“无法将值NULL插入列’Sessionid’,表’master.dbo.Column’;列不允许空值.INSERT失败。 r n语句已终止。”}

“Sessionid”列实际上是主键,用[KEY]标记如下:

  public class Customers { [Key] public long Sessionid { get; set; } public long? Pers { get; set; } } 

所以根据这个问题,似乎当属性用[KEY]标记时,EF忽略了我自己的Sessionid声明,因为它期望数据库分配值。

那我怎么解决这个问题呢? 如果我删除[KEY]我得到"entity type has no key defined"exception…

我通过添加[DatabaseGenerated(DatabaseGeneratedOption.None)]解决了这个问题:

 public class Customers { [Key] [DatabaseGenerated(DatabaseGeneratedOption.None)] public long Sessionid { get; set; } public long? Pers { get; set; } } 

您可以将SQL配置为在插入时自动生成(并自动增加)表的主键。 然后只需删除C#中的[Key],您不需要手动设置应用程序中的ID,db会为您生成它。

上述就是C#学习教程:无法在ASP.NET MVCentity framework中将值NULL插入到列中分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/1039306.html

(0)
上一篇 2022年1月26日
下一篇 2022年1月26日

精彩推荐