Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 用户结帐和客人结帐:在Django中使用这两者的最佳方式_Python_Django_Database_Django Models - Fatal编程技术网

Python 用户结帐和客人结帐:在Django中使用这两者的最佳方式

Python 用户结帐和客人结帐:在Django中使用这两者的最佳方式,python,django,database,django-models,Python,Django,Database,Django Models,实际上,我需要关于处理客人结帐和客户结帐的最佳实践的建议。 我有一个场景,一个订单可以有多个产品(这不是问题)。我的点菜台像 class Orders(models.Model): customer= models.ForeignKey(Customer, on_delete=models.CASCADE) order_number = models.AutoField(primary_key=True) total_amount = models.DecimalFiel

实际上,我需要关于处理客人结帐和客户结帐的最佳实践的建议。 我有一个场景,一个订单可以有多个产品(这不是问题)。我的点菜台像

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来使用现有的顺序表吗?或者我应该为这个制作一张单独的订单表?最好的办法是什么

根据您提供的信息,我会将
Customer.customerProfile
设置为空,并将其设置为
None
,用于客人结账。

在客人结账时,您是否收集了任何会进入客户模型的信息?@schillingt yes first\u name,last\u name,email,电话etcso无需为客人订单创建新模型?请验证设计和逻辑是否正确?不,不需要新模型。我不知道我需要在哪里进行更改?在客户表中?你能把编辑过的代码贴出来吗@希利格特