EF:插入记录失败,提示当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
  TEZNKK3IfmPf 2024年04月19日 27 0
EF忽然报错:
增加记录时,提示当 IDENTITY_INSERT 设置为 OFF 时,不能向表 '。。。' 中的标识列插入显式值。
真奇怪,添加记录方法一向好地地,从没出过错。要出错,那也是Update时才会,什么“附着不附着”的问题。
从提示信息来看,是向标识列插入了值。那么EF为什么会认不出标识列呢?
原来,是因为同事首先生成了EF代码,然后再在数据库中将某字段改成了标识列,改完以后,没有刷新EF代码,因此EF没有认出该

字段为标识列。
在.edmx文件里,查看其代码,对实体类有如下描述:
        <EntityType Name="Status_Info">
          <Key>
            <PropertyRef Name="ID" />
          </Key>
          <Property Name="ID" Type="int" StoreGeneratedPattern="Identity" Nullable="false" />
          <Property Name="StatusID" Type="int" />
          <Property Name="Color" Type="nchar" MaxLength="10" />
        </EntityType>

是否标识列,一目了然。

教训:数据库更改,一定要刷新EF代码。

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2024年04月19日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2024年04月26日   25   0   0 数据库sqljava
  TEZNKK3IfmPf   2024年04月19日   30   0   0 数据库postgresql
TEZNKK3IfmPf