栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

2021-10-17 Django 学习,数据库外键的设置

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

2021-10-17 Django 学习,数据库外键的设置

Django 学习,数据库外键的设置 model.ForeignKey() TypeError: init() missing 1 required positional argument: ‘on_delete’

建立外键的时候碰到上述报错

class Student(models.Model):
    s_name = models.CharField(max_length=20)
    s_age = models.IntegerField(default=15)
    s_class = models.ForeignKey(S_Class) 

当你在设置多对一关系时,必须要设置级联删除,也就是当你删除一条信息时,会级联的删除所有和这一条信息对应的另一张表的多个信息,也就是指定on_delete=models.CASCADE

正确的代码应当是
class Student(models.Model):
    s_name = models.CharField(max_length=20)
    s_age = models.IntegerField(default=15)
    s_class = models.ForeignKey(S_Class, on_delete=models.CASCADE) 
Cannot assign “1”: “Student.s_class” must be a “S_Class” instance

添加数据是碰到以上错误,是因为Django 的orm 设置都是要先查询才能做增删改

def add_student(request):
    student = Student()
    student.s_name = 'mei%d' % randrange(100)
    student.s_class=2
    student.save()
    return HttpResponse('添加成功')
正确的代码应为
def add_student(request):
    student = Student()
    student.s_name = 'mei%d' % randrange(100)
    student.s_class=S_Class.objects.get(pk=1)
    student.save()
    return HttpResponse('添加成功')
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/329462.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号