Драйвер MongoDb C # не обновляет мой внутренний список - PullRequest
0 голосов
/ 24 февраля 2019

У меня есть этот метод для добавления новых данных в NozzleStateList:

    public async Task AddNozzleState(NozzleState nozzleState, Guid tankId, Guid gasStationId)
        {
            UpdateDefinition<GasStation> update = Builders<GasStation>.Update.Push("TankList.$[t].NozzleList.$[n].NozzleStateList", nozzleState);


            await _context.GetCollection<GasStation>().UpdateOneAsync(x => x.Id == gasStationId, update, new UpdateOptions
            {
                ArrayFilters = new List<ArrayFilterDefinition>{
                    new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("t._id", tankId)),
            new BsonDocumentArrayFilterDefinition<BsonDocument>(new BsonDocument("n._id", nozzleState.NozzleId))
                }
            });
        }

и коллекция, в которую он должен быть помещен, выглядит так: enter image description here метод AddNozzleState выполняется безошибка но ничего не сохраняет.В чем проблема?

1 Ответ

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

Наконец, я изменил свой подход и использовал JsonArrayFilterDefinition, и этот код работает:

public async Task AddNozzleState(NozzleState nozzleState, Guid tankId, Guid gasStationId)
        {
            UpdateDefinition<GasStation> update = Builders<GasStation>.Update.Push("TankList.$[t].NozzleList.$[n].NozzleStateList", nozzleState);


            await _context.GetCollection<GasStation>().UpdateOneAsync(x => x.Id == gasStationId, update, new UpdateOptions
            {
                ArrayFilters = new List<ArrayFilterDefinition>{
                    new JsonArrayFilterDefinition<Tank>("{'t._id': { $eq : UUID(\""+ tankId +"\")} }"),
                    new JsonArrayFilterDefinition<Nozzle>("{'n._id': { $eq : UUID(\""+ nozzleState.NozzleId+"\")}}")
                }
            });
        }
...