ホームページ >バックエンド開発 >C++ >最初に EF コードで 10 進データ型の精度とスケールを構成するにはどうすればよいですか?

最初に EF コードで 10 進データ型の精度とスケールを構成するにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2025-01-21 23:32:20565ブラウズ

How to Configure Precision and Scale for Decimal Data Types in EF Code First?

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 つのパラメータを受け入れます:

  • 精度: 小数点の位置に関係なく、データベースが保存する合計桁数を指定します。
  • scale: データベースに保存される小数点以下の桁数を指定します。

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。