No se puede crear un valor constante de tipo Solo se admiten tipos primitivos o tipos de enumeración en este contexto
Estoy recibiendo este error para la consulta a continuación
No se puede crear un valor constante de tipo
API.Models.PersonProtocol
. Solo se admiten tipos primitivos o tipos de enumeración en este contexto
ppCombined
a continuación se muestra un objeto IEnumerable
de PersonProtocolType
, que está construido por concat de 2 listas PersonProtocol
.
¿Por qué está fallando esto? ¿No podemos usar la cláusula LINQ JOIN
dentro de SELECT
de a JOIN
?
var persons = db.Favorites
.Where(x => x.userId == userId)
.Join(db.Person, x => x.personId, y => y.personId, (x, y) =>
new PersonDTO
{
personId = y.personId,
addressId = y.addressId,
favoriteId = x.favoriteId,
personProtocol = (ICollection<PersonProtocol>) ppCombined
.Where(a => a.personId == x.personId)
.Select( b => new PersonProtocol()
{
personProtocolId = b.personProtocolId,
activateDt = b.activateDt,
personId = b.personId
})
});
3 answers
Esto no puede funcionar porque ppCombined
es una colección de objetos en memoria y no puede unir un conjunto de datos de la base de datos con otro conjunto de datos que esté en memoria. En su lugar, puede intentar extraer los elementos filtrados personProtocol
de la colección ppCombined
en memoria después de haber recuperado las otras propiedades de la base de datos:
var persons = db.Favorites
.Where(f => f.userId == userId)
.Join(db.Person, f => f.personId, p => p.personId, (f, p) =>
new // anonymous object
{
personId = p.personId,
addressId = p.addressId,
favoriteId = f.favoriteId,
})
.AsEnumerable() // database query ends here, the rest is a query in memory
.Select(x =>
new PersonDTO
{
personId = x.personId,
addressId = x.addressId,
favoriteId = x.favoriteId,
personProtocol = ppCombined
.Where(p => p.personId == x.personId)
.Select(p => new PersonProtocol
{
personProtocolId = p.personProtocolId,
activateDt = p.activateDt,
personId = p.personId
})
.ToList()
});
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2013-09-22 13:45:52
No sé si alguien busca esto. Yo tenía el mismo problema. Un select en la consulta y luego haciendo el where (o join) y usando la variable select resolvió el problema para mí. (el problema estaba en la colección "Reintegraties" para mí)
query.Select(zv => new
{
zv,
rId = zv.this.Reintegraties.FirstOrDefault().Id
})
.Where(x => !db.Taken.Any(t => t.HoortBijEntiteitId == x.rId
&& t.HoortBijEntiteitType == EntiteitType.Reintegratie
&& t.Type == TaakType))
.Select(x => x.zv);
Espero que esto ayude a alguien.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2017-11-23 14:31:24
En mi caso, pude resolver el problema haciendo lo siguiente:
Cambié mi código de esto:
var r2 = db.Instances.Where(x => x.Player1 == inputViewModel.InstanceList.FirstOrDefault().Player2 && x.Player2 == inputViewModel.InstanceList.FirstOrDefault().Player1).ToList();
A esto:
var p1 = inputViewModel.InstanceList.FirstOrDefault().Player1;
var p2 = inputViewModel.InstanceList.FirstOrDefault().Player2;
var r1 = db.Instances.Where(x => x.Player1 == p1 && x.Player2 == p2).ToList();
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2018-02-07 00:21:20