我正在使用EF Core值转换。
https://docs.microsoft.com/en-us/ef/core/modeling/value-conversions
我写了一个JSON序列化转换器,如下所示:
private static ValueConverter<T, String> JsonValueConverter<T>()
{
ValueConverter<T, String> jsonConverter = new ValueConverter<T, String>(
v => JsonConvert.SerializeObject(v),
v => JsonConvert.DeserializeObject<T>(v));
return jsonConverter;
}
在应用中实现:
protected override void OnModelCreating(ModelBuilder mb)
{
...
mb.Entity<MyObject>()
.Property(p => p.MySerializableObject)
.HasConversion(JsonValueConverter<MySerializableObject>());
...
}
有效。
但是,当您对序列化对象内部的属性进行更改时,EF Core更改跟踪不会获取对MySerializableObject
的更改。
我认为有某种方法可以在对象级别上强制执行此操作。我尝试在IEqualityComparer
上实现MySerializableObject
,但更改跟踪无法开始。
答案 0 :(得分:1)
通过向属性的Metadata中添加ValueConverter
和ValueComparer
,我可以进行变更跟踪,但是,我的比较器效率很低。如果有人对性能调整提出建议,将不胜感激。
mb.Entity<MyObject>().Property(p => .MySerializableObject).HasJsonConversion();
使用新的HasJsonConversion扩展方法
public static class ValueConversionExtensions
{
public static PropertyBuilder<T> HasJsonConversion<T>(this PropertyBuilder<T> propertyBuilder)
{
ValueConverter<T, String> converter = new ValueConverter<T, String>(
v => JsonConvert.SerializeObject(v),
v => JsonConvert.DeserializeObject<T>(v));
ValueComparer<T> comparer = new ValueComparer<T>(
(l, r) => JsonConvert.SerializeObject(l) == JsonConvert.SerializeObject(r),
v => v == null ? 0 : JsonConvert.SerializeObject(v).GetHashCode(),
v => JsonConvert.DeserializeObject<T>(JsonConvert.SerializeObject(v)));
propertyBuilder.HasConversion(converter);
propertyBuilder.Metadata.SetValueConverter(converter);
propertyBuilder.Metadata.SetValueComparer(comparer);
return propertyBuilder;
}
}