owner = models.ForeignKey(User)出现TypeError

owner = models.ForeignKey(User)出现错误 TypeError: init() missing 1 required positional argument: ‘on_delete’

owner = models.ForeignKey(User)

出现下列错误:

TypeError: __init__() missing 1 required positional argument: 'on_delete'

解决办法:

owner = models.ForeignKey(User, on_delete=models.CASCADE)
  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
根据你提供的代码,报错出现在 `pro_price` 字段上的 `models.DecimalField(20, 2)` 上面。`DecimalField` 字段需要指定一个字符串参数作为第一个参数,用于表示最大位数和小数位数。修改该行代码为 `pro_price = models.DecimalField(max_digits=20, decimal_places=2)` 即可解决问题。 修正后的代码如下: ```python class Product(models.Model): # 商品id,主键,唯一,自增 pro_id = models.AutoField(primary_key=True) pro_p = models.IntegerField() pro_name = models.CharField(max_length=64) pro_addr = models.CharField(max_length=64) pro_intro = models.CharField(max_length=64) pro_img = models.ImageField() pro_deta = models.ImageField() pro_price = models.DecimalField(max_digits=20, decimal_places=2) pro_stock = models.IntegerField() pro_q = models.IntegerField(default=1) # 商品状态默认在售 pro_desc = models.TextField(null=True) # 店铺id,是外键 pro_store_id = models.ForeignKey(to="Store", on_delete=models.CASCADE) # 商品评价id,是外键 pro_rate_id = models.ForeignKey(to="Rate", to_field="rate_id", on_delete=models.CASCADE) # 与购物车表的关系是多对多 pro_cart = models.ManyToManyField(to="Cart") # 与订单表的关系是多对多 pro_orders = models.ManyToManyField(to="Orders") # 与店铺信息表的关系是一对一 pro_store = models.OneToOneField(to="Store", on_delete=models.CASCADE) ``` 请注意,`max_digits` 表示允许的最大位数,包括整数部分和小数部分,而 `decimal_places` 表示小数的位数。根据你的需求,你可以相应地调整这两个参数的值。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

steventian72

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值