gpt4 book ai didi

entity-framework-core - 使用值转换器时如何查询 Entity Framework 核心中的实际值?

转载 作者:行者123 更新时间:2023-12-05 01:52:10 24 4
gpt4 key购买 nike

我们有一个相当简单的情况,其中 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()

关于entity-framework-core - 使用值转换器时如何查询 Entity Framework 核心中的实际值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71704235/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com