[MSSQL] [EntityFramework(.Net Core)] 自增长id字段,无法插入数据

IDENTITY_INSERT 为 OFF,无法插入数据,

类似的错误,解决记录:

 

网上查了下,都是 Code First 模式下的解决方案,

如:在 DBContext 的 OnModelCreating 方法里面

// EntityFramework .NET Core
modelBuilder.Entity<Project>().Property(t => t.Id).ValueGeneratedOnAdd();

//...

// EntityFramework
modelBuilder.Entity<Project>().Property(t => t.Id)
    .HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);

 

或:在实体类的定义里给 id 加注解如下

[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }

 


 

以上方法,在不采用各种模式的情况下,没有起作用,

最后发现,只要前端在给后端传json时,只要不传 id 这个字段就可以了,

然而手残地给传了给默认值 -1 。。。

其实本来就没有问题的(后端接受参数时是用类对象接收的,id默认会是0,这时Add方法正常,而给0以外的值时就会报错,无法给自增列赋值)

 

转载于:https://www.cnblogs.com/CoderMonkie/p/entityframework-identity-insert.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值