Оформление заказа пользователем и выезд гостя: лучший способ использовать оба в Django - PullRequest
0 голосов
/ 18 марта 2020

На самом деле мне нужно предложение о наилучшей практике для обработки гостей и клиентов. У меня есть сценарий, что 1 заказ может иметь несколько продуктов (что не является проблемой). Моя таблица заказов выглядит как

class Orders(models.Model):
    customer= models.ForeignKey(Customer, on_delete=models.CASCADE)
    order_number = models.AutoField(primary_key=True)
    total_amount = models.DecimalField(max_digits=10, decimal_places=2)
    ordertime = models.DateTimeField(auto_now_add=True)
    order_status = models.CharField(max_length=50)
    is_placed = models.BooleanField(default=False)

, а затем она связана с таблицей продуктов следующим образом

class OrderProduct(models.Model):
    order=models.ForeignKey(Orders, on_delete=models.CASCADE)
    activity = models.ForeignKey(ActivityOrganizer, on_delete=models.CASCADE)
    participants=models.IntegerField(default=0)
    totalPrice=models.DecimalField(max_digits=10, decimal_places=2)
    checkIn = models.DateField()
    language = models.CharField(max_length=50, null=False, blank=False)

И моя таблица клиентов -

class Customer(models.Model):
    customerProfile = models.OneToOneField(User, on_delete=models.CASCADE)
    first_name=models.CharField(max_length=50, null=False, blank=False)
    last_name=models.CharField(max_length=50, null=False, blank=False)
    email=models.CharField(max_length=50, null=False, blank=False)
    mobile_number=models.CharField(max_length=50, null=False, blank=False)
    profile_image=models.ImageField(null=True, upload_to='CustomerProfile')
    is_customer=models.BooleanField(default=False)
    city=models.CharField(max_length=50, null=True, blank=True)
    gender=models.CharField(max_length=50, null=True, blank=True)
    verification_key = models.CharField(max_length=100, null=True, blank=True)
    def __str__(self):
        return str(self.first_name)

Теперь я хочу Включить гостевые проверки также. Затем я должен использовать существующие таблицы порядка, разрешив Foregin ключ Null? Или я должен сделать отдельные таблицы заказов для этого? Какой будет лучший способ?

1 Ответ

1 голос
/ 19 марта 2020

Исходя из представленной вами информации, я бы сделал Customer.customerProfile обнуляемым и установил бы ее на None для гостевых проверок.

...