使用值转换器时如何查询实体框架核心中的实际值?

2024-03-01

我们有一个相当简单的情况,其中 EF Core 实体包含一个我们映射到字符串的值对象:

builder.Property(_ => _.Nummer)
    .HasConversion(i => i.ToString(), i => ZijdeNummer.FromString(i))
    .IsRequired().HasMaxLength(9);

这对于检索和存储来说效果很好,但对于过滤,我们正在寻找一种按子字符串过滤行的方法。如果是正常的话string列你可以简单地做这样的事情:

dbSet.TheTable.Where(t => t.Nummer.Contains("some text")).ToList()

明显是习俗ZijdeNummer不包含公认的.Contains()方法。我尝试过使用.ToString().Contains()但可惜的是,这也行不通。

最后,我还尝试访问该列,就好像它是影子属性一样:

dbSet.TheTable.Where(t => EF.Property<string>(t, "Nummer").Contains("some text"))

但它不会被愚弄,因为它仍然知道EF.Property<T>(t, "Nummer")实际上不是一个字符串:(

有没有办法让 EF-Core 只查询原始列类型?


事实证明这比您想象的要容易得多。只需将类型转换为字符串(如果不存在转换,则首先转换为对象)并执行比较:

dbSet.TheTable.Where(t => ((string)(object)t.Nummer).Contains("some text")).ToList()
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用值转换器时如何查询实体框架核心中的实际值? 的相关文章

随机推荐