Значение не может быть нулевым исключением во время выполнения в троичном операторе в проекции EF core 2.1 - PullRequest
0 голосов
/ 25 января 2019

На самом деле у меня проблемы с тем, что я не могу установить нулевое значение вместо значения по умолчанию для поля, допускающего обнуляемость.

Я не могу написать правильный код с EF core 2.1 в операторе select, потому что я столкнулся с исключительной ситуацией во время выполнения "значение не может быть нулевым" или невозможно использовать нулевой оператор распространения.

Примечание: если это важно, строки, взятые из подобъекта в запросе.

VotedAt = i.CurrentUserVote == null 
    ? new DateTimeOffset() 
    : i.CurrentUserVote.VotedAt,
CurrentUserVote = i.CurrentUserVote == null 
    ? false 
    : i.CurrentUserVote.IsPositive,

Я бы хотел написать:

VotedAt = i.CurrentUserVote == null 
    ? null 
    : i.CurrentUserVote.VotedAt,
CurrentUserVote = i.CurrentUserVote == null 
    ? null 
    : i.CurrentUserVote.IsPositive,

Или даже:

VotedAt = i.CurrentUserVote?.VotedAt,
CurrentUserVote = i.CurrentUserVote?.IsPositive,

Другая запрошенная информация от сообщества: Выбранный объект:

public class IssueListItem
{
    public int Id { get; set; }
    public string Title { get; set; }
    public Votes Votes { get; set; }
}

public class Votes
{
    public int Positive { get; set; }
    public int Negative { get; set; }
    public int All { get; set; }
    public bool? CurrentUserVote { get; set; }
    public DateTimeOffset? VotedAt { get; set; }
}

Выбор:

        return _unitOfWork.Issues.GetQuery()
                .Filter(query.Filter)
                .WithVotes<Issue, IssueVote, int>(currentUserId)
                .Order(query.Sorter)
                .Select(i => new IssueListItem
                {
                    Id = i.Item.Id,
                    Votes = i.Votes,
                    Title = i.Item.Title,
                    //removed some other properties
                })
                .ToListAsync();

, где WithVotes<Issue, IssueVote, int>(currentUserId):

            return q
                .Select(i => new
                {
                    Item = i,
                    VoutesGroups = i.Votes
                        .GroupBy(v => v.IsPositive, v => true, (key, vg) => new { IsPositive = key, Count = vg.Count() }),
                    CurrentUserVote = currentUserId == null ? null : i.Votes.FirstOrDefault(v => v.CreatedById == currentUserId),
                })
                .Select(i => new AssignVotesModel<TEntity, TVote, TId>
                {
                    Item = i.Item,
                    Votes = new Votes
                    {
                        Positive = i.VoutesGroups.Where(vg => vg.IsPositive == true).Sum(vg => vg.Count),
                        Negative = i.VoutesGroups.Where(vg => vg.IsPositive == false).Sum(vg => vg.Count),
                        All = i.VoutesGroups.Sum(vg => vg.Count),
                        VotedAt = i.CurrentUserVote == null ? new DateTimeOffset() : i.CurrentUserVote.VotedAt,
                        CurrentUserVote = i.CurrentUserVote == null ? false : i.CurrentUserVote.IsPositive,
                    }
                });

1 Ответ

0 голосов
/ 25 января 2019

Определенный столбец, вероятно, не может быть пустым в базе данных, или в вашей сущности Mapping.

Убедитесь, что ваша модель сущности не имеет атрибута Required. Также убедитесь, что указанное свойство не помечено Required в конфигурации modelBuilder.

Наконец, проверьте столбец таблицы в вашей РСУБД, установлен ли он как IS NOT NULL

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...