加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Entity Framework问题:ReferentialConstraint 中的依赖属性映射

发布时间:2020-12-13 23:15:15 所属栏目:百科 来源:网络整理
导读:今天在采用Entity Framework 的Database First反向以及用Code First写的数据库表时,在测试时一直出现以下错误: 情况是这样的: 我有两张表,记主表为A,辅表为B(即外键所在的表,设外键为Id,同时也是表B的主键) 这个问题是因为: 我的表B中的键Id不仅是

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




情况是这样的:

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

这个问题是因为:

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

解决方法:

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


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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读