сервиса, нужно добиться того, чтобы с одинаковыми параметрами  создавался только один заказ.
                  
                  
                  Кусок сериализатора создания заказа:
                  
                  
                  
                  
                  
                  with transaction.atomic():
                  
                  
                      qs = self.Meta.model.objects.select_for_update(of=('self', ))
                  
                  
                      order, is_created = qs.get_or_create(
                  
                  
                          **vd,
                  
                  
                          dish_list__isnull=False,
                  
                  
                          defaults={
                  
                  
                              'delivery_service_request_data': delivery_service_request_data,
                  
                  
                          })
                  
                  
                  if is_created:
                  
                  
                            .......
                  
                  
                  
                  
                  
                  Проблема в том, что при отправке запросов с одинаковыми параметрами (**vd - словарь с некими параметрами в методе get_or_create ) создается два заказа подряд. А требуется чтобы если один заказ уже создан такой, мы просто вернули этот заказ.
                  
                  
                  
                  
                  
                  Подскажите,пожалуйста , в какую сторону копать ?!  Уже дошел до уровней изоляции транзакции , но чувствую , что это неверный путь) 
                  
                  
                  Спасибо заранее !
                  
                  
                
странно. https://docs.djangoproject.com/en/3.2/ref/models/querysets/#get-or-create This is meant to prevent duplicate objects from being created when requests are made in parallel Не должно быть дублей. Почему они появляются?
запросы отправляются с разницей 0.1 секунды - то есть почти одновременно
Так как бы цитата из доки именно про это. Не должно. Но у меня таких нагруженных проектов не было. Поэтому, к сожалению, вынужден промолчать.
я понял) по сути это две паралельные транзакции , которые создают запись в БД если говорить об изменении данных в БД , то обернуть в блок atomic и ок , а вот насчет создания нигде инфы не могу найти ...
Обсуждают сегодня