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
                 })
        });
Author: user2515186, 2013-09-21

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()
        });
 182
Author: Slauma,
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.

 2
Author: Roelant,
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();
 2
Author: Versatile,
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