我们有一个相当简单的情况,其中 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(使用前将#替换为@)