前面我们追加数据的时候遗留下来一个问题,就是在追加数据的时候,票价(Price)字段中输入的是9.99元,但是电影清单显示画面中该数据的票价字段显示为10元,这是为什么?这个问题发生的原因是因为,当EF code-first在创建数据表的时候,如果字段为Decimal类型,则使用默认的精度(18:0),从而使得9.99元被四舍五入成为10元。现在我们想要将这个默认的精度修改为(18:2),从而使得数据表中的票价字段能够存储小数点后的两位数字。可喜的是EF code-first允许你很容易地重载这个定义模型如何向数据库中存取数据的映射规则。你可以利用这个重载机制来重载EF code-first中默认的类型定义以及数据表的继承规则,然后在这个基础上进行数据的存取。为了改变我们的票价(Price)字段在数据表中的精度,打开Models文件夹下的Movie.cs文件。追加一句引用System.Data.Entity.ModelConfiguration的语句,代码如下:

using System.Data.Entity.ModelConfiguration;

并在MovieDBContext类中重载OnModelCreating方法,代码如下所示:

public class MovieDBContext : DbContext
{
    public DbSet<Movie> Movies { get; set; }
 
    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
    modelBuilder.Entity<Movie>().Property(p => p.Price).HasPrecision(18, 2);
    }
}
View Code

相关文章:

  • 2021-12-02
  • 2021-07-03
  • 2022-02-25
  • 2022-02-21
  • 2021-12-26
  • 2021-09-04
  • 2021-06-10
  • 2022-01-24
猜你喜欢
  • 2021-11-19
  • 2021-06-27
  • 2021-12-29
  • 2021-07-06
  • 2021-07-15
  • 2021-11-17
  • 2021-05-21
相关资源
相似解决方案