解决Entity Framework中自增主键的问题

 更新时间:2025年06月19日 15:08:55   作者:nihao_yang  
这篇文章主要介绍了解决Entity Framework中自增主键的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Entity Framework中自增主键问题

当实体类中有int类型的字段,并且该字段对应数据库中的主键,那么Entity Framework会自动将该字段设为自动增长。

若此时数据库中对应的主键并非是自动增长的,则在插入数据时会出现异常。

举个例子:

若有如下实体类Test和数据库表Test。

public class Test
{
    public int Id { get; set; }
    public string Name { get; set; }
}
create table Test(
    Id int primary key,
    Name varchar(20)
);

Entity Framework会将实体类Test的Id字段设为自动增长的,而此时表Test中的主键Id并没有设为自动增长。若此时向数据表Test插入数据则会出现异常。

Mysql数据库虽然会插入成功,但插入数据的Id为始终0。而SqlServer则直接出现异常,无法插入。

解决办法1

将数据表中的Id设为自增

create table Test(
    Id int primary key auto_increment,
    Name varchar(20)
);

解决办法2

在实体类Test的Id字段添加注解

using System.ComponentModel.DataAnnotations.Schema
public class Test
{
    [DatabaseGenerated(DatabaseGeneratedOption.None)]
    public int Id { get; set; }
    public string Name { get; set; }
}

解决办法3

在相应的DbContext中添加

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity<Test>().Property(p => p.ID)
    .HasDatabaseGeneratedOption(DatabaseGeneratedOption.None); 
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Unity接入百度AI实现果蔬识别

    Unity接入百度AI实现果蔬识别

    本文将介绍如何利用Unity接入百度AI从而实现果蔬识别,可以做到识别近千种水果和蔬菜的名称,可自定义返回识别结果数。感兴趣的小伙伴可以了解一下
    2022-02-02
  • C# Guid.NewGuid获得随机数

    C# Guid.NewGuid获得随机数

    根据GUID获得种子,然后获得随机数,这个是完全随机的
    2013-04-04
  • C#优化if...else代码的方案总结

    C#优化if...else代码的方案总结

    在编写代码实现业务需求过程中,会使用到大量的if...else 判断语句,随业务复杂程度不同,导致判断语句出现多层嵌套、多分支等情况,导致代码可读性变差、增加维护难度,本文介绍了C# 如何优化 if...else 让代码优雅起来,需要的朋友可以参考下
    2024-06-06
  • C#装饰器模式(Decorator Pattern)实例教程

    C#装饰器模式(Decorator Pattern)实例教程

    这篇文章主要介绍了C#装饰器模式(Decorator Pattern),以一个完整实例形式讲述了C#装饰器模式的实现过程,有助于深入理解C#程序设计思想,需要的朋友可以参考下
    2014-09-09
  • C#如何利用结构体对固定格式数据进行解析

    C#如何利用结构体对固定格式数据进行解析

    这篇文章主要为大家详细介绍了C#利用结构体对固定格式数据进行解析,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Unity3D Ui利用shader添加效果

    Unity3D Ui利用shader添加效果

    这篇文章主要为大家详细介绍了Unity3D Ui利用shader添加效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • 将ocx文件转换成C#程序引用的DLL文件的办法

    将ocx文件转换成C#程序引用的DLL文件的办法

    将ocx文件转换成C#程序引用的DLL文件的办法,需要的朋友可以参考一下
    2013-03-03
  • C# 创建单例的多种方式

    C# 创建单例的多种方式

    这篇文章主要介绍了C# 创建单例的多种方式,帮助大家更好的理解和学习使用c#,感兴趣的朋友可以了解下
    2021-03-03
  • 深入分析c# 继承

    深入分析c# 继承

    这篇文章主要介绍了c# 继承的相关资料,文中讲解的非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • 结合.net框架在C#派生类中触发基类事件及实现接口事件

    结合.net框架在C#派生类中触发基类事件及实现接口事件

    这篇文章主要介绍了结合.net框架在C#派生类中触发基类事件及实现接口事件,示例的事件编程中包括接口和类的继承等面向对象的基础知识,需要的朋友可以参考下
    2016-02-02

最新评论