Entity Framework Group на основе нулевого столбца первичного ключаC#

Место общения программистов C#
Ответить
Anonymous
 Entity Framework Group на основе нулевого столбца первичного ключа

Сообщение Anonymous »

Моя организация для хранения адреса выглядит ниже и ссылается на несколько таблиц как иностранный ключ, например, страновой континент и т. Д. < /p>

Код: Выделить всё

public class ContactAddress
{
[Key]
public int Id { get; set; }

[ForeignKey(nameof(Contact))]
public int ContactId { get; set; }

public virtual  Contact Contact { get; set; }

[ForeignKey(nameof(Continent))]
public int? ContinentId { get; set; }

public virtual  Continent Continent { get; set; }

[ForeignKey(nameof(Country))]
public int? CountryId { get; set; }

public virtual  Country Country { get; set; }
}
Попытка получить подсчет значений адресов по в стране и континенту и составить результат в список , что похоже на
public class GeoStatsModel
{
public int Id { get; set; } // Country Id
public string Name { get; set; } //Country Name
public int Count { get; set; }
}
< /code>
удалось генерировать запрос, как ниже < /p>
List response = new List();

response = context.ContactAddresses
.Where(a => a.IsPrimary == true && contactIds.Contains(a.ContactId))
.GroupBy(a => a.CountryId)
.Select(g => new GeoStatsModel
{
Id = (int)g.Key,
Name = (g.First().Country!=null)? g.First().Country.Name: "",
Count = g.Count()
}).ToList();
< /code>
На момент выполнения я получаю ошибку: < /p>

выражение Linq /> Valuebufferexpression:
projectionbindingexpression: umptyprocemember
isnullable: false < /p>
.select(s => s.country) .first () 'не может быть переведено. Либо
Перепишите запрос в форме, которая может быть переведена, либо перейти на
клиентскую оценку явно, вставив призыв к «Asenumerable»,
'Asasyncemerable', 'tolist' или 'tolistasync'. См.
https://go.microsoft.com/fwlink/?linkid=2101038 для получения дополнительной информации.>

Подробнее здесь: https://stackoverflow.com/questions/709 ... key-column
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»