I have this model as you can see here :
public class car
{
public int Id { set; get; }
public string Name { set; get; }
public CarBody CarBody { get; set; }
public car( string name, CarBody carBody)
{
Name = name;
CarBody = new CarBody(carBody.VIN);
}
private car()
{
}
}
And inside this class car
I have another value object named CarBody
public class CarBody
{
public VIN VIN { get; set; }
public CarBody(VIN vin)
{
VIN = vin;
}
private CarBody()
{
}
}
And VIN Model
public class VIN
{
public string value { get; set; }
public VIN(string value)
{
this.value = value;
}
private VIN()
{
}
}
I need to execute a query using EFCORE 3.1
on VIN
inside CarBody
as you can see here :
public Domain.PetrolReceptions.PetrolReception GetLastOpenNotCanceledByVIN(string vin,
double openPetrolTestTimeInDays)
{
var result = _dbContext.PetrolReceptions.Where(g =>g.Car.carBody.vin == vin ).ToList();
return result.FirstOrDefault();
}
But after executing the query I got this error:
The LINQ expression 'DbSet<PetrolReception>
.Where(p => p.Car.carBody.vin == __vin_0)' could not be translated. Either rewrite the query in a form that can be translated, or switch to client evaluation explicitly by inserting a call to either AsEnumerable(), AsAsyncEnumerable(), ToList(), or ToListAsync(). See https://go.microsoft.com/fwlink/?linkid=2101038 for more information.
Here is the configEntity
configuration
public class CarConfig : IEntityTypeConfiguration<car>
{
public void Configure(EntityTypeBuilder<car> builder)
{
builder.Property(c => c.CarBody).HasConversion(c => JsonConvert.SerializeObject(c),
c => JsonConvert.DeserializeObject<CarBody>(c));
}
}
Thanks in Advance.