文档章节

Django学习笔记(5)---ForeignKey

Linktime
 Linktime
发布于 2013/01/29 21:25
字数 402
阅读 11662
收藏 1

ForeignKey在Django中是Many-To-One类型,即有多个对象绑定到一个对象的意味

先来看例子

from django.db import models

class User(models.Model):
    name = models.CharField(max_length=30)

class Group(models.Model):
    name = models.CharField(max_length=30)
    owner = models.ForeignKey(User)
    member = models.ManyToMany(User)

模型中如果有外键和多对多字段,创建的时候外键必须首先绑定,然后保存,才能添加多对多字段。

例如

from models import User,Group

#第一种创建对象的方法必须调用save()函数,否则不会真正向数据库写入
u1 = User()
u1.name = 'ZhangSan'
u1.save()

#一次创建并写入数据库,与上面的等价
u2 = User.objects.create(name='LiSi')

g = Group()
g.name = "My group"
g.owner = u1
g.save() #必须调用save函数写入数据库后才能添加多对多,否则Group对象在数据库中没有对应primary_key无法建立关联
g.member.add(u2)

按如上代码,g对象与u1对象绑定,当调用u1.delete()时,g对象也会被删除!!!


此外,还有一种方法建立对象之间的关联

from django.db import models

class User(models.Model):
    name = models.CharField(max_length=30)

class Group(models.Model):
    name = models.CharField(max_length=30)
    member = models.ManyToMany(User,through='Friendship')

class Friendship(models.Model):
    #通过through属性建立了Group与User之间的关系,在Friendship中必须有两个外键与其绑定
    owner = medels.ForeignKey(User)
    group = medels.ForeignKey(Group)

这种方法比起前一种关系结构更明确,但是操作起来需要的语句更加多一些。即当User和Group的对象中有任意一个被删除,这种关系自动解除,虽然这里举的例子并不能很好诠释。


转载请注明出处,谢谢!

© 著作权归作者所有

共有 人打赏支持
Linktime
粉丝 20
博文 11
码字总数 5181
作品 0
嘉定
技术主管
加载中

评论(2)

Linktime
Linktime

引用来自“ponyfk”的评论

第二段代码13行是,g.owner = u1

谢谢指出
flyking
flyking
第二段代码13行是,g.owner = u1
Django学习笔记(2)

Django官方文档里有一个投票Web应用的例子。建立好的目录如下: mysite是project的名字,polls是这个应用。 接下来梳理一下这个应用的数据库和实现。 表结构 在Sqlite3中建立两个表,是投票信...

兔之
2015/09/05
44
0
Django 学习笔记之模型高级用法(上)

前面有两篇文章简单介绍 Django 的模型,这一部分算是基础知识。我自己近期也总做了下总结,将花大概两篇的篇幅来分享下模型的一些高级用法。 如果想熟悉 Django 的用法,我认为应该一开始要...

猴哥Yuri
04/27
0
0
models数据模型学习笔记

每个应用一般都会定义一个或多个models,这个数据models实际上是与数据库相关的,models中的每个属性都是数据库当中的一个字段,每个字段是数据库中的一个列。在models中定义的每个类相当于数...

不折腾难受斯基
2016/05/24
106
0
Django学习笔记之——Models

Django里的模型是对数据库对表的一次封装,是应用业务与数据之间的桥梁。 1. 模型的Fields 在上一节,我们在mysite/blog/models.py中创建了BlogPost这个Model。 from django.db import mode...

临峰不畏
2015/03/06
0
0
Django学习笔记(6)---多应用、多数据库

前一段在学习过程中,想的都比较简单,所以就只有一个应用一个数据库,但是当写的东西多了就发觉不同功能应该由不同应用来处理,不同应用可以使用单独使用自己的数据库,这样比较利于网站的扩...

Linktime
2013/02/12
0
2

没有更多内容

加载失败,请刷新页面

加载更多

Java动态代理之InvocationHandler最简单的入门教程

网上关于Java的动态代理,Proxy和InvocationHandler这些概念有讲解得非常高深的文章。其实这些概念没有那么复杂。现在咱们通过一个最简单的例子认识什么是InvocationHandler。值得一提的是,...

JerryWang_SAP
23分钟前
0
0
oracle 在 MyBatis 中使用 like

两种使用方法 使用oracle自带 || 拼凑的方式 <if test="userName!=null and userName!=''"> AND u.USER_NAME like '%' || #{userName} || '%' </if> 使用MyBatis的$符号的方式 <if test="us......

karma123
29分钟前
1
0
带接口的webservice方式发布

package cn.it.ws.e;import javax.jws.WebService;/** * 面向接口的webservice发布方式 * @author Administrator * */@WebServicepublic interface JobService {publi...

江戸川
44分钟前
2
0
day122-20181020-英语流利阅读-待学习

蜘蛛侠新片《毒液》来袭!导演灵感来自哪? Roxy 2018-10-20 1.今日导读 你还记得漫威宇宙中飞檐走壁的蜘蛛侠小可爱吗?在刚过去的国庆黄金周里,索尼影业发行的漫威超级英雄蜘蛛侠系列大片《...

飞鱼说编程
55分钟前
4
0
美团点评Docker容器管理平台

美团点评容器平台简介 本文介绍美团点评的Docker容器集群管理平台(以下简称“容器平台”)。该平台始于2015年,是基于美团云的基础架构和组件而开发的Docker容器集群管理平台。目前该平台为...

Skqing
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部