Entity Framework 保存操作中の検証の問題: 詳細
「1 つ以上のエンティティの検証に失敗しました...」エラーがよく発生しますEntity Framework を使用してデータベースに変更を保存するときに発生します。これは、データ型の不一致、または .NET オブジェクトとデータベース フィールド間の不適切な変換が原因である可能性があります。
この特定のシナリオでは、Event クラスは DateTime および TimeSpan データ型を定義しますが、対応するデータベース列の型は Date、それぞれ時間と時間。この型の不一致により、検証エラーが発生する可能性があります。
適切なデータ型へのキャスト
この問題を解決するには、変更を保存する前に適切なデータ型にキャストする必要があります。コードを変更する方法は次のとおりです。
public class Event { // Convert to SQL Server-compatible types before saving public DateTime EventDate { get => EventDate.Date; set => _eventDate = value; } public TimeSpan StartTime { get => TimeSpan.Parse(StartTime.ToString("hh\:mm")); set => _startTime = value; } public TimeSpan EndTime { get => TimeSpan.Parse(EndTime.ToString("hh\:mm")); set => _endTime = value; } }
検証エラーのデバッグ
さらにトラブルシューティングを行うには、次のコードを使用してすべての検証情報を取得できます。
try { storeDB.SaveChanges(); } catch (DbEntityValidationException dbEx) { foreach (var validationErrors in dbEx.EntityValidationErrors) { foreach (var validationError in validationErrors.ValidationErrors) { Console.WriteLine("Property: {0} Error: {1}", validationError.PropertyName, validationError.ErrorMessage); } } }
このコードはプロパティ レベルの検証エラーをすべて表示し、正確な原因を特定できるようにします。
結論
正しいデータ型にキャストし、検証エラーのデバッグを組み込むことで、「検証に失敗しました」問題を解決し、変更をシームレスに保存できます。 Entity Framework を使用してデータベースを作成します。将来の検証エラーを避けるために、データ型の互換性を常に考慮してください。
以上がEntity Framework が「検証に失敗しました」エラーをスローするのはなぜですか? それらをデバッグして解決するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。