Entity Framework问题:ReferentialConstraint 中的依赖属性映射由存储生成的列

简介: 原文: Entity Framework问题:ReferentialConstraint 中的依赖属性映射由存储生成的列 今天在采用Entity Framework 的Database First反向以及用Code First写的数据库表时,在测试时一直出现以下错误: 情况是这样的: 我有两张表,记主表为A,辅表为B(即外键所在的表,设外键为Id,同时也是表B的主键) 这个问题是因为: 我的表B中的键Id不仅是外键,也具有自增属性,即在建表是用Identity标识之。
原文: Entity Framework问题:ReferentialConstraint 中的依赖属性映射由存储生成的列

今天在采用Entity Framework 的Database First反向以及用Code First写的数据库表时,在测试时一直出现以下错误:




情况是这样的:

我有两张表,记主表为A,辅表为B(即外键所在的表,设外键为Id,同时也是表B的主键)

这个问题是因为:

我的表B中的键Id不仅是外键,也具有自增属性,即在建表是用Identity标识之。而这两个功能是矛盾的。一方面,作为FK,Id的值为主表A决定;另一方面,Id又要求自增。

解决方法:

目标:去除自增功能。但是无法直接在字段上修改,因此可以考虑删除字段重建列,或者是重建表。并更正主键与外键。


由于在SQL-SERVER中,自增列属性不能直接修改,但可以通过以下方式变向实现
 
1、如果仅仅是指定值插入,可用以下语句,临时取消
 
SET  IDENTITY_INSERT TableName  ON
INSERT  INTO  tableName(xx,xx)  values (xx,xx)
SET  IDENTITY_INSERT TableName  OFF
 
2、新增一列,删除自增列,修改改列名
 
alter  table  add  xxx  int
update  set  xxx=id
alter  table  drop  column  id
exec  sp_rename  'xxx' 'id' 'column'
 
3、通过修改系统关于该表的列属性,该方法使用不当将可能引起其它不可预料的错误
 
sp_configure  'allow update' ,1
reconfigure  with  override
go
update  syscolumns  set  colstat=0  where  colstat=1  and  id=object_id( 'tablename' )
go
sp_configure  'allow update' ,0
reconfigure  with  override

4、重建表,注意在该字段不再采用Identity标识。


目录
相关文章
|
8月前
|
SQL Java 数据库连接
2021-08-05mapper代理,几种pojo输入输出,pojo扩展通过扩展继承,映射主键普通属性映射,动态SQL,逆向工程
2021-08-05mapper代理,几种pojo输入输出,pojo扩展通过扩展继承,映射主键普通属性映射,动态SQL,逆向工程
45 0
|
5月前
|
Java 数据库连接 mybatis
Mybatis中对象映射关联之collection使用
Mybatis中对象映射关联之collection使用
58 0
|
API 数据库
Entity Framework复杂类型属性映射
Entity Framework复杂类型属性映射
122 0
Entity Framework复杂类型属性映射
|
数据库 C#
Entity Framework 简单属性映射
Entity Framework 简单属性映射
1068 0
Entity Framework 简单属性映射
|
数据库 C#
Entity Framewor简单属性映射
Entity Framewor简单属性映射
78 0
Entity Framewor简单属性映射
|
SQL 监控 索引
AutoMapper自动映射
十年河东,十年河西,莫欺少年穷。 学无止境,精益求精。 不扯犊子,直接进入正题: AutoMapper自动映射常用于EF中,能很好的解决DTO和Model之间相互映射的问题。在未使用AutoMapper之前,我们回顾下传统的对象相互映射的方法。
2058 0
|
存储 缓存 数据库
ORM映射框架总结--实体分析器
1.       什么是数据分析器 前面一篇文章讲到过数据分析器,什么是数据分析器。其实很容易理解,就是对数据进行分析采集的一个工具,说白了就是一个小程序,在本ORM框架中对实体对象进行必要的数据分析,获得实体对象的各种信息缓存,以便在后续的工作中直接提取数据。
742 0