模拟数据库上下文中的自动增量主键

如何解决模拟数据库上下文中的自动增量主键

有谁知道如何在我的模拟数据库上下文中自动增加主键?我正在对一个方法进行单元测试,当我想将两个项目添加到我的模拟数据库上下文时,我收到一条错误消息,提示“已添加具有相同键的项目”。所以我应该找到一种方法来设置我的数据库上下文模拟,这样每次添加一个项目时,它都会添加不同的主键。 这是我在服务类中的方法

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 中。所以具有相同键的项目不能在数据库中。 在以下两种情况下,您不能将此属性用于主键:

  1. 如果您的主键是外键
  2. 当你的主键有 ValueGeneratedNever() 方法时

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?