如何解决模拟数据库上下文中的自动增量主键
有谁知道如何在我的模拟数据库上下文中自动增加主键?我正在对一个方法进行单元测试,当我想将两个项目添加到我的模拟数据库上下文时,我收到一条错误消息,提示“已添加具有相同键的项目”。所以我应该找到一种方法来设置我的数据库上下文模拟,这样每次添加一个项目时,它都会添加不同的主键。 这是我在服务类中的方法:
public async Task<ProductDTO> CreateProduct(ProductDTO dto)
{
foreach (var i in dto.Products)
{
if (i.ProductId == 0)
{
// New product
var product = Product.CreateMyProductDto(i);
_db.Products.Add(product);
}
}
// rest of the code …
}
所以在这里我们查看 dto.products,如果任何产品的 productId 为零,那么我们通过调用 Product.CreateMyProductDto 函数创建我们的产品并将其添加到 Products 表中。在下面的单元测试中,我有两个 productId = 0 的产品,因此应该将它们添加到 Products 表中,但是由于主键,我在添加第二个产品时出现错误。
[Fact]
public async Task TestForCreateProduct()
{
//Arrange
List<Product> products = new List<Product>();
Product product1 = new Poduct()
{
ProductId = 0
};
Product product2 = new Poduct()
{
ProductId = 0
};
// add to the products list
products.Add(product1);
products.Add(product2);
ProductDTo dto = new ProductDTO()
{
Products = products
};
// create mock
DbContextMock<MyContext> context_Moq = new DbContextMock<MyContext>(DummyOptions);
// set up mock
context_Moq.CreateDbSetMock(x => x.Products,new[]
{
new Product { EntityId = 1,Name = "product1"},new Product { EntityId = 2,Name = "product2"},new Product { EntityId = 3,Name = "product3"}
});
var service = new myService(context_Moq.Object);
// Act
var result = await service.CreateProduct(dto);
// Assert
Assert.Equal(5,context_Moq.Object.Products.Count());
}
我正在使用 .NET core3,所以有人能帮我解决这个错误吗?我需要在我的模拟数据库上下文中有自动递增的主键。
解决方法
我终于可以解决这个问题了。正如您在下面看到的,EntityId 是我的 Product 类中的主键,我使用 [Key,DatabaseGenerated(DatabaseGeneratedOption.Identity)] 属性来为 EntityId 设置自动递增标识列
public class Product
{
[Key,DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public long EntityId { get; set; }
// rest of the code
}
在这种情况下,项目被添加到我的模拟 dbContext 中,EntityIds 从 1 开始。 假设您使用具有 EntityId 1 的一项设置您的 dbContext。然后 您调用 Add 函数将产品添加到 Products 表中,您将收到相同的错误,因为它尝试添加 EntityId 1 的产品,该产品已经在您的模拟 dbContext 中。所以具有相同键的项目不能在数据库中。 在以下两种情况下,您不能将此属性用于主键:
- 如果您的主键是外键
- 当你的主键有 ValueGeneratedNever() 方法时
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。