微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何找出导致实体框架错误的行?

如何解决如何找出导致实体框架错误的行?

我要在我的数据库添加一系列数据。

IList<Data> items = //326 rows of data

using(MyDataContext c = new MyDataContext()){
     c.MyTable.AddRange(items);
     c.SaveChanges();
}

但有时它会像下面这样抛出 dbupdateException。

ORA-12899:SM.TB.NAME 列的值太大(实际:265,最大值:255)

但是我看不懂哪一行数据?我怎样才能找到它?

我应该向用户返回一条警告消息,此数据无效。

解决方法

您应该在尝试保存数据之前验证数据。也许是这样的:

// Find the invalid items
var invalidItemIds = items
    .Where(x => x.Name.Length > 255)
    .Select(x => x.Id);

if (invalidItemIds.Any())
{
    // If there is invalid items,handle it the way of your choice
    throw new Exception($"The name is too long for items: {string.Join(",",invalidItemIds)}");
}
,

与我的 dbcontext 的 MyTable 关联的 SM.TB DB 表的 Name 列大小太小 - 255 个字符,您至少需要 265 个。您必须更改 MyTable 类的属性名称

[Column(TypeName = "VARCHAR2")]
 [StringLength(512,MaximumLength = 255)]
public string Name{ get; set; }

或流利的Api

modelBuilder.Entity<MyTable>()
  .Property(e => e.Name).HasColumnType("VARCHAR2").HasMaxLength(255);

如果您确实需要超过 255 个,请将您期望的数字更改为 Max。

将表迁移到数据库。或者,如果您知道如何更改,也可以直接在 OracleDb 中更改它。使用这个脚本

ALTER TABLE SM.TB
MODIFY Name VARCHAR2( 512 );

作为一种解决方法,只需添加名称长度检查代码(请参阅@kaffekopp 的答案)并在可能的情况下将字符串剪切为 255

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。