数値をデータ型数値に変換する際の算術オーバーフローエラー。EFコア

キースバロウズ

以下のエラーが発生している列を特定しようとしています。サードパーティのサービスによって提供された受信データについて何かが変更され、SQLに保存しようとすると失敗するようになりました。

Microsoft.EntityFrameworkCore.DbUpdateException:エントリの更新中にエラーが発生しました。詳細については、内部例外を参照してください。---> System.Data.SqlClient.SqlException:数値をデータ型数値に変換する際の算術オーバーフローエラー。ステートメントは終了されました。

非常に単純なフロー:

  • サードパーティのAPIをJSONとして読み取る
  • newtonsoftを使用して、EFデータモデルクラスに直接変換します
  • レコードをDBに追加してから保存します。

データ構造は次のように定義されます。

[JsonObject(MemberSerialization.OptIn)]
public class RatDbAttributes
{
    [JsonProperty]
    [StringLength(50)]
    public string block_chain { get; set; } // varchar(50)
    [JsonProperty]
    [StringLength(50)]
    public string block_reduction { get; set; } // varchar(50)
    [JsonProperty]
    [StringLength(50)]
    public string block_reward { get; set; } // varchar(50)
    [JsonProperty]
    public double block_time { get; set; } // decimal(28,6)
    [JsonProperty]
    [StringLength(100)]
    public string consensus_method { get; set; } // varchar(100)
    [JsonProperty]
    public decimal decimals { get; set; } // decimal(28,6)
    [JsonProperty]
    [StringLength(50)]
    public string difficulty_retarget { get; set; } // varchar(50)
    [JsonProperty]
    [StringLength(200)]
    public string genesis_address { get; set; } // varchar(200)
    [JsonProperty]
    [StringLength(100)]
    public string hash_algorithm { get; set; } // varchar(100)
    [JsonProperty]
    [StringLength(50)]
    public string mineable { get; set; } // varchar(50)
    [JsonProperty]
    public long p2p_port { get; set; } // bigint
    [JsonProperty]
    public long rpc_port { get; set; } // bigint
    [JsonProperty]
    [StringLength(200)]
    public string token_role { get; set; } // varchar(200)
    [JsonProperty]
    public decimal @float { get; set; } // decimal(28,6)
    [JsonProperty]
    public decimal minted { get; set; } // decimal(28,6)
    [JsonProperty]
    public decimal total_supply { get; set; } // decimal(28,6)
    [JsonProperty]
    public decimal max_supply { get; set; } // decimal(28,6)
    [JsonProperty]
    [StringLength(133)]
    public string wallet { get; set; } // varchar(133)
    [JsonProperty]
    [NotMapped]
    public double genesis_timestamp { get; set; } // see below

    [JsonIgnore]
    public DateTime Genesis_TimeStamp { get { return genesis_timestamp.ToDateTime(); } set { genesis_timestamp = value.ToEpoch(); } }


    // Foregin Key Relationship (1-to-1) and Primary Key
    [JsonIgnore]
    public long TokenMasterId { get; set; }
    [JsonIgnore]
    [ForeignKey("TokenMasterId")]
    public RatDbTokenMaster TokenMaster { get; set; } //foreign key to Parent
}

私はダブルチェックしましたがgenesis_timestamp、それは問題ではありません(ダブルを日時に変換する)。

着信失敗JSONのサンプル:

{"block_chain":""
,"block_reduction":""
,"block_reward":"0"
,"block_time":0.0
,"consensus_method":""
,"decimals":0.0
,"difficulty_retarget":""
,"genesis_address":""
,"hash_algorithm":""
,"mineable":"False"
,"p2p_port":0
,"rpc_port":0
,"token_role":""
,"float":0.0
,"minted":0.0
,"total_supply":0.0
,"max_supply":0.0
,"wallet":""
,"genesis_timestamp":0.0
}
キースバロウズ

バッチが失敗した場合のフェイルオーバー反復保存を作成しました。このクラスのデータベース接続を「グローバル」にしたので、うっかりして問題が発生しました。レコードセットを追加して保存しようとし(エラーポップ)、問題のあるレコードを見つけるために、ますます小さなバッチを繰り返してみます。問題は、反復する前に問題のあるレコードセットを削除しなかったことです。したがって、すべての反復でDB接続にエラー状態が発生しました。

    internal void IterateSave<TModel>(List<TModel> items) where TModel : class
    {
        using (LogContext.PushProperty("Data: Class", nameof(RatBaseCommandHandler)))
        using (LogContext.PushProperty("Data: Method", nameof(IterateSave)))
        using (LogContext.PushProperty("Data: Model", nameof(items)))
        {
            int max = items.Count;
            int skip = 0;
            int take = (max > 20) ? (max / 5) : 1;
            int lastTake = take;
            List<TModel> subItems = new List<TModel>();

            while (skip <= max)
            {
                try
                {
                    subItems = items.Skip(skip).Take(take).ToList();
                    Log.Verbose("Working {Max} | {Take} | {Skip}", max, take, skip);

                    skip += take;
                    _db.Set<TModel>().AddRange(subItems);
                    _db.SaveChanges();
                }
                catch (Exception ex)
                {
/***** Was not removing the faulty record/recordset! *****/
                    _db.Set<TModel>().RemoveRange(subItems);
/***** Was not removing the faulty record/recordset! *****/

                    if (take == 1 && skip < max)
                    {
                        Log.Error(ex, "Error saving specific record in this data batch! {GuiltyRecord}", JsonConvert.SerializeObject(subItems));
                        if (skip >= max - 1)
                        {
                            depth--;
                            return;
                        }
                    }
                    else if (take > 1)
                    {
                        Log.Warning("Something is wrong saving this data batch! {RecordCount}  Running a smaller batch to isolate.", take);
                        IterateSave(subItems);
                    }
                }
            }
        }
    }

これらの2行が追加されると(catchのコメントセクション)、エラーは文字通りすぐに飛び出しました!

このデータバッチに特定のレコードを保存するときにエラーが発生しました。"[{\" block_chain \ ":\" Ethereum \ "、\" block_reduction \ ":\" \ "、\" block_reward \ ":\" 0 \ "、\" block_time \ ":0.0、\" consensus_method \ ":\" \ "、\" decimals \ ":18.0、\" difficulty_retarget \ ":\" \ "、\" genesis_address \ ":\" 0x3520ba6a529b2504a28eebda47d255db73966694 \ "、\" hash_algorithm \ ":\" \ "、\ "mineable \":\ "False \"、\ "p2p_port \":0、\ "rpc_port \":0、\ "token_role \":\ "\"、\ "float \":0.0、\ "minted \ ":60000000000000000000000000.0、\" total_supply \ ":60000000000000000000000000.0、\" max_supply \ ":60000000000000000000000000.0、\" wallet \ ":\" \ "、\" Genesis_timestamp \ ":0.0}]" Microsoft.EntityFrameworkCore.DbUpdateException:エントリの更新中にエラーが発生しました。詳細については、内部例外を参照してください。---> System.Data.SqlClient.SqlException:数値をデータ型数値に変換する際の算術オーバーフローエラー。ステートメントは終了されました。

C#はDECIMALデータ型で60000000000000000000000000.0を処理できますが、SQLはDECIMAL(28,6)で定義されています。6桁の精度のため、10 ^ 22の値のスペースしか残されません。

(SQLがDECIMAL(38,6)を処理できるようになりました。実動データを失うことなく列定義を試す時間です。)

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

分類Dev

SUM(myfield):数値をデータ型数値に変換する算術オーバーフローエラー

分類Dev

SQLで数値をデータ型数値に変換する算術オーバーフローエラー

分類Dev

varcharをデータ型数値(SQL)に変換する算術オーバーフローエラー

分類Dev

varcharをデータ型数値に変換する算術オーバーフローエラー?

分類Dev

エラーがある、数値をデータ型数値に変換する算術オーバーフローエラー

分類Dev

ストアドプロシージャでvarcharをデータ型数値に変換する算術オーバーフローエラー

分類Dev

クエリ実行時に数値をデータ型数値に変換する算術オーバーフローエラー

分類Dev

asp.netでvarcharを数値型のデータ型に変換する算術オーバーフローエラー

分類Dev

式をデータ型nvarcharに変換する際の算術オーバーフローエラー。

分類Dev

GUIDを他のデータ型に変換するT-SQL算術オーバーフローエラー

分類Dev

IDENTITYをデータ型intに変換しているが、intの最大値に達していないSQLServer算術オーバーフローエラー

分類Dev

varcharを数値型に変換する算術オーバーフローエラー-適合する答えが見つかりません

分類Dev

IDENTITYをデータ型tinyintに変換する算術オーバーフローエラー

分類Dev

where句の値を制限するときにvarcharを10進数に変換するSQL算術オーバーフローエラー

分類Dev

T-SQLコードで式をデータ型intメッセージに変換する算術オーバーフローエラー

分類Dev

ストアドプロシージャ算術オーバーフローエラー式をデータ型intに変換しています

分類Dev

OracleをPostgreSQLに変換する際の数値オーバーフロー

分類Dev

varcharを10進数に変換する算術オーバーフローエラー

分類Dev

temptable 列 (10 進数) を 10 進数に変換していますが、「varchar をデータ型 numeric に変換する算術オーバーフロー エラー」が引き続き発生します。

分類Dev

MINを使用する場合-式をデータ型datetimeに変換する算術オーバーフローエラー

分類Dev

メッセージ8115、レベル16、状態2、行2式をデータ型intに変換する算術オーバーフローエラー

分類Dev

データ型varcharを数値に変換する際のエラーを修正しました。(8114)(SQLExecDirectW) ')

分類Dev

型varchar値の算術オーバーフローエラー= 770214566.000000000

分類Dev

データ型varcharを数値に変換する際のエラーとしてエラーが発生するトリガー

分類Dev

JavaScriptの算術演算で数値のオーバーフロー/アンダーフローを検出するにはどうすればよいですか?

分類Dev

タイプintの算術オーバーフローエラー、値= 4957500001.400178

分類Dev

smallintの算術オーバーフローエラー-しかし、データ型はintですか?

分類Dev

実行が成功した後、エラーが発生しました:式をデータ型intに変換する算術オーバーフローエラー

分類Dev

算術オーバーフローで最大値を取得する

Related 関連記事

  1. 1

    SUM(myfield):数値をデータ型数値に変換する算術オーバーフローエラー

  2. 2

    SQLで数値をデータ型数値に変換する算術オーバーフローエラー

  3. 3

    varcharをデータ型数値(SQL)に変換する算術オーバーフローエラー

  4. 4

    varcharをデータ型数値に変換する算術オーバーフローエラー?

  5. 5

    エラーがある、数値をデータ型数値に変換する算術オーバーフローエラー

  6. 6

    ストアドプロシージャでvarcharをデータ型数値に変換する算術オーバーフローエラー

  7. 7

    クエリ実行時に数値をデータ型数値に変換する算術オーバーフローエラー

  8. 8

    asp.netでvarcharを数値型のデータ型に変換する算術オーバーフローエラー

  9. 9

    式をデータ型nvarcharに変換する際の算術オーバーフローエラー。

  10. 10

    GUIDを他のデータ型に変換するT-SQL算術オーバーフローエラー

  11. 11

    IDENTITYをデータ型intに変換しているが、intの最大値に達していないSQLServer算術オーバーフローエラー

  12. 12

    varcharを数値型に変換する算術オーバーフローエラー-適合する答えが見つかりません

  13. 13

    IDENTITYをデータ型tinyintに変換する算術オーバーフローエラー

  14. 14

    where句の値を制限するときにvarcharを10進数に変換するSQL算術オーバーフローエラー

  15. 15

    T-SQLコードで式をデータ型intメッセージに変換する算術オーバーフローエラー

  16. 16

    ストアドプロシージャ算術オーバーフローエラー式をデータ型intに変換しています

  17. 17

    OracleをPostgreSQLに変換する際の数値オーバーフロー

  18. 18

    varcharを10進数に変換する算術オーバーフローエラー

  19. 19

    temptable 列 (10 進数) を 10 進数に変換していますが、「varchar をデータ型 numeric に変換する算術オーバーフロー エラー」が引き続き発生します。

  20. 20

    MINを使用する場合-式をデータ型datetimeに変換する算術オーバーフローエラー

  21. 21

    メッセージ8115、レベル16、状態2、行2式をデータ型intに変換する算術オーバーフローエラー

  22. 22

    データ型varcharを数値に変換する際のエラーを修正しました。(8114)(SQLExecDirectW) ')

  23. 23

    型varchar値の算術オーバーフローエラー= 770214566.000000000

  24. 24

    データ型varcharを数値に変換する際のエラーとしてエラーが発生するトリガー

  25. 25

    JavaScriptの算術演算で数値のオーバーフロー/アンダーフローを検出するにはどうすればよいですか?

  26. 26

    タイプintの算術オーバーフローエラー、値= 4957500001.400178

  27. 27

    smallintの算術オーバーフローエラー-しかし、データ型はintですか?

  28. 28

    実行が成功した後、エラーが発生しました:式をデータ型intに変換する算術オーバーフローエラー

  29. 29

    算術オーバーフローで最大値を取得する

ホットタグ

アーカイブ