增加记录时,提示当 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代码。