这是我第一次使用模型创建Django网站,并且在我第一次尝试将数据插入表中时遇到此错误。
我的模型如下:
class User(AbstractUser):
pass
#https://docs.djangoproject.com/en/3.1/topics/auth/default/
class Listing(models.Model):
listingID = models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name="listID")
created_by = models.ForeignKey(User, on_delete=models.SET_NULL, related_name="myListing", null=True)
watchers = models.ManyToManyField(User, blank=True, related_name="watchlist")
title = models.CharField(max_length=30)
description = models.TextField()
creation_date = models.DateField(auto_now=True)
img_url = models.URLField()
active = models.BooleanField(default=True)
def __str__(self):
return f"{self.title}"
class Bid(models.Model):
listing = models.ForeignKey(Listing, on_delete=models.SET_NULL, related_name="bidsMadeOnMe", null=True, blank=True)
user = models.ForeignKey(User, on_delete=models.SET_NULL, related_name="myBids", null=True)
price = models.FloatField()
creation_date = models.DateField(auto_now=True, null=True)
def __str__(self):
return f"Bid={self.price}"
处理表单提交的视图是这样的:
@login_required
def create_listing(request):
if request.method == "POST":
user = User.objects.get(username=request.user.username)
l = Listing(created_by=user,
title=request.POST["title"],
description=request.POST["desc"],
# https://stackoverflow.com/questions/12176585/handling-dates-over-request-get
creation_date=models.DateTimeField(auto_now_add=True),
img_url=request.POST["image_url"]
)
l.save()
b = Bid(l,
user,
request.POST["initial_bid"],
models.DateTimeField(auto_now_add=True)
)
b.save()
return render(request, "auctions/index.html")
我知道问题是我添加数据的方式,但是我无法解决它。有人可以给我一些光吗?
答案 0 :(得分:0)
您的问题(嗯,实际上是几个)是
b = Bid(l, user, request.POST["initial_bid"], models.DateTimeField(auto_now_add=True))
您正在通过位置参数而不是关键字参数来构建模型实例。可以这样做,但是添加到Bid模型中的不可见的“ id”列是第一个参数。
在Django中,我们从不构造这样的模型,但始终使用关键字参数,因此我们不依赖于字段顺序:
b = Bid(listing=l, user=user, ...))
解决后,下一个问题就是日期字段。
请勿将字段分配给模型实例。字段是类声明,它们不属于实例。字段在类(=模型)上描述期望的数据类型。在实例上,分配该数据。
在这种情况下,您对字段的定义在模型上是错误的,甚至在实例上您都不应该分配它-它会自动填充。
总的来说,您似乎没有经历Django's tutorial或没有完全理解这些概念。我建议你经历一下。