EF Code First で 10 進データ型の精度と位取りを構成する
EF Code First では、System.Decimal 型のプロパティは、デフォルトでデータベース内の decimal(18, 0) 型の列にマップされます。データの整合性を維持し、数値演算の精度を確保するには、これらの列の精度 (保存される合計桁数) とスケール (保存される小数点以下の桁数) をカスタマイズすることが重要です。
Dave Van den Eynde の元の回答では、EF 4.0 以前では、精度を調整する推奨方法は、プロパティを反復処理し、modelBuilder.Entity().Property().HasPrecision() を Entity() とともに使用することであると示唆されていました。プロパティ().HasScale()。ただし、このアプローチは最近の EF バージョンでは非推奨になりました。
EF 4.1 以降、DecimalPropertyConfiguration.HasPrecision メソッドは、よりシンプルで効率的なソリューションを提供します。 2 つのパラメータを受け入れます:
EF Code First で精度とスケールを設定するための構文は次のとおりです:
<code class="language-csharp">public class EFDbContext : DbContext { protected override void OnModelCreating(System.Data.Entity.DbModelBuilder modelBuilder) { modelBuilder.Entity<MyClass>().Property(m => m.MyProperty).HasPrecision(12, 10); base.OnModelCreating(modelBuilder); } }</code>
このアプローチを使用すると、10 進数属性の精度と位取りを明示的に定義でき、データベース列が必要なデータ形式と範囲を正確に表すことができます。これは、高い精度が必要な財務データやその他の機密データを扱う場合に特に重要です。
以上が最初に EF コードで 10 進データ型の精度とスケールを構成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。