首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当列是标识列时,NDbUnit不设置XML中指定的主键字段。

当列是标识列时,NDbUnit不设置XML中指定的主键字段。
EN

Stack Overflow用户
提问于 2011-09-14 18:07:57
回答 1查看 338关注 0票数 1

我正在使用NDbUnit对数据访问层进行单元测试。

在构造XSD和相关XML文件时,一切都很正常,这些XML文件用于用行数据填充各种表。但是,我刚刚注意到,当整数PK列是identity列时,我无法通过XML直接设置PK。

也就是说,当数据库自动处理行插入中的增量和PK设置时,NDbUnit无法覆盖它并自行设置它(据我所见)。

对于NDbUnit来说,有什么方法可以覆盖这个标识列值并直接从XML中设置它吗?还是我被Server为插入的行创建的自动递增值困住了?还是应该使用另一种模式来插入带有标识列的行,然后在另一个表的行中使用该值作为FK?

更新:

我发现,在执行NDbUnit数据库操作时,需要将参数设置为InsertIdentity,而不仅仅是插入:

代码语言:javascript
复制
INDbUnitTest database = new NDbUnit.Core.SqlClient.SqlDbUnitTest(connectionString);
database.PerformDbOperation(DbOperationFlag.InsertIdentity);

但是,即使在进行此更改之后,在插入行时,也会出现以下错误:

被设置为OFF时,IDENTITY_INSERT不能在表'myTable‘中插入标识列的显式值。

这将使我相信,在InsertIdentity方法上设置的NBDUnit标志实际上并没有将Server中特定表的IDENTITY_INSERT设置为OFF。

对为什么不会发生这种事有什么建议吗?

EN

回答 1

Stack Overflow用户

发布于 2014-11-21 13:48:28

希望迟到总比没有好,但我今天也遇到了同样的问题。

在XSD上,高亮显示identity列并点击F4。当出现“属性”窗格时,您可能会看到AutoIncrement设置为False。将此更改为True,它将开始工作。不知道为什么在随机情况下会发生这种情况,但希望这能帮助你解决问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7420920

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档