django2外键

Posted fengzi7314

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django2外键相关的知识,希望对你有一定的参考价值。

一对多

环境

两个类:书的类别和文章,一片文章只能有一个作者,一个作者可以有多个文章,这之间组成了一对多的关系

class Category(models.Model):
    category = models.CharField(max_length=100)

    def __str__(self):
        return self.category



class Article(models.Model):
    title = models.CharField(max_length=20,verbose_name=书名)
    info = models.TextField(verbose_name=内容)
    author = models.CharField(max_length=10, verbose_name=作者)
    f = models.ForeignKey(to=Category,on_delete=models.CASCADE)#如果不想用article_set这种形式查找,可以使用related_name=‘articles‘,那么在视图one_to_many函数中就可以使用articles = category.articles.all()

添加文章

def add_article(request):
    article = Article(title=钢铁是怎样炼成的,info=不知道,author=疯子)
    article.f = Category.objects.get(id=1)
    article.save()
    return HttpResponse(添加文章成功)

 

通过书的类型查找文章

def one_to_many(request):
    category = Category.objects.first()
    articles = category.article_set.all()#all可以换成filter或者first
    for i in articles:
        print(i.title)
        print(i.author)
        print(i.content)
    return HttpResponse(ok)

 

 

一对一

环境

如果一张表里面字段非常都可以考虑把一张表拆成2张表,这样在查询的时候比在一张表上查询速度快,例子:一个用户表,一个用户扩展信息表,这是一对一个关系,一个用户只能对应一个扩展信息,同样的道理,一个用户扩展信息只能对应一个用户

 

models.py内容

class Users(models.Model):
    name = models.CharField(max_length=10)
    # def __str__(self):
    #     return ‘name:%s‘ % self.name

class Users_Extend(models.Model):
    school = models.CharField(max_length=100)
    telephone = models.CharField(max_length=11)
    extend_info = models.OneToOneField(Users, on_delete=models.CASCADE)

 

view视图

#通过用户查看用户的扩展信息
def
one_to_one(request): # users = Users(name=‘疯子‘) # users.save() # extend = Users_Extend(school=‘交通大学‘,telephone=120) # extend.extend_info_id = 1 # extend.save() extend = Users_Extend.objects.first() print(extend.extend_info.name) return HttpResponse(添加用户成功)

 

view视图

#通过扩展信息查看用户
def one_to_one(request):
    users = Users.objects.first()
    print(users.users_extend)
    return HttpResponse(添加用户成功)

 

以上是关于django2外键的主要内容,如果未能解决你的问题,请参考以下文章

Django2.0 models中的on_delete参数

Django 2.0:sqlite IntegrityError:外键约束失败

Django的外键创建

Django2.0中的on_delete字段取值含义

django 2.0外键处理

Django 关系类型字段