0

我正在开发一个新的代码优先实体框架(使用 dbMigration)解决方案,但我遇到了一些我无法克服的障碍。

即使我修改了生成的迁移文件以将十进制字段的精度/小数位数设置为 18 和 9,但当我运行 update-database 来构建数据库并调用我编写的方法来播种数据时,它会将数据四舍五入为2 位小数,而不是我预期的 9 位。在我尝试播种的示例数据中,我尝试将 Price 属性设置为 0.4277,但它在数据库中显示为 0.420000000

我一直在寻找解决这个问题的方法,包括为 OnModelCreating 创建一个覆盖(在我的上下文类中),以强制那里的精度/比例。但是当我把它准备好时(参见下面代码中注释掉的行),虽然数据库迁移仍然完全按计划工作(包括按预期创建 DECIMAL(18,9)),但现在 Seed 调用不运行.

我希望我只是缺少一些小东西(而且很容易修复)。但是任何人都可以提供我可以尝试的建议吗?

下面是相关代码(包括最初生成的迁移代码):

public class Product
{
    public int ID { get; set; }
    public decimal Price { get; set; }
}

internal sealed class Configuration : DbMigrationsConfiguration<ConfiguratorContext>
{
    public Configuration()
    {
        AutomaticMigrationsEnabled = true;
    }

    protected override void Seed(ConfiguratorContext context)
    {
        //  This method will be called after migrating to the latest version.

        //  You can use the DbSet<T>.AddOrUpdate() helper extension method 
        //  to avoid creating duplicate seed data.
        SeedData.Initialize();        
    }
}

public partial class Initial : DbMigration
{
    public override void Up()
    {
        CreateTable(
            "dbo.Products",
            c => new
            {
                ID = c.Int(nullable: false, identity: true),
                Price = c.Decimal(nullable: false, precision: 18, scale: 9)
                })
            .PrimaryKey(t => t.ID);
    }   

    public override void Down()
    {
        DropTable("dbo.Products");
    }       
}   

public class ConfiguratorContext : DbContext
{
    public ConfiguratorContext() : base("name=ConfiguratorConnectionString")
    {
        Database.SetInitializer<ConfiguratorContext>(new CreateDatabaseIfNotExists<ConfiguratorContext>());
    }

    public DbSet<Product> Products { get; set; }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        //modelBuilder.Entity<Product>().Property(a => a.Price).HasPrecision(18, 9);
    }
}

public class SeedData
{
    public static void Initialize()
    {
        using (var context = new ConfiguratorContext())
        {
            if (context.Products.Any())
            {
                return;   // DB has been seeded
            }

            context.Products.Add(new Product
            {
                Price = Convert.ToDecimal(0.4277),
            });

            context.SaveChanges();
        }
    }
}   

我错过了什么?

谢谢!

4

2 回答 2

1

我认为您的迁移没有执行,并且decimal(18, 2)默认情况下创建了数据库。

您可以尝试使用以下初始化程序,但它不会为您创建数据库

Database.SetInitializer<ConfiguratorContext>(new MigrateDatabaseToLatestVersion<ConfiguratorContext, Configuration>());

你评论的那一行modelBuilder.Entity<Product>().Property(a => a.Price).HasPrecision(18, 9);做得恰到好处。

如果可以的话,我建议不要使用自动迁移,并通过更新数据库Update-Database来获得一致且可预测的数据库架构更改结果。

于 2018-04-19T17:30:23.993 回答
0
  • 首先,不要注释 OnModelCreating 方法的主体。这将确保数据库中价格列的精度。
  • 在种子方法中设置这样的值: Price = 0.4277minstad of Price = Convert.ToDecimal(0.4277),
于 2018-04-17T20:46:49.960 回答