Django--models连表构建
需求
models多表(一对多、多对多、一对一)的构建
速查
1、一对多
1
2
3
|
class User(models.Model): name = models.CharField(max_length = 10 ) gender = models.ForeignKey(外键表名, |
2、多对多
1
2
3
|
class User(models.Model): name = models.CharField(max_length = 10 ) hobby = models.ManyToManyField(Hobby) |
3、一对一
1
2
3
|
class User(models.Model): name = models.CharField(max_length = 10 ) salary = models.OneToOneField(Salary,to_field = "name" ) |
知识点
1、连表结构
一对多:models.ForeignKey(其他表),A表的一个字段对应B表的多个字段;
多对多:models.ManyToManyField(其他表),A表中的一个字段对应B表中的多行(自动创建一关系表);
一对一:models.OneToOneField(其他表),
2、应用场景
一对多:当一张表中创建一行数据时,有一个单选的下拉框(可以被重复选择)
例如:创建用户信息时候,需要选择一个用户类型【普通用户】【金牌用户】【铂金用户】等。多对多:在某表中创建一行数据时,有一个可以多选的下拉框
例如:创建用户信息,需要为用户指定多个爱好一对一:在某表中创建一行数据时,有一个单选的下拉框(下拉框中的内容被用过一次就消失了)
例如:原有含10列数据的一张表保存相关信息,经过一段时间之后,10列无法满足需求,需要为原来的表再添加5列数据
详细
1、一对多--ForeignKey
1.1 默认连接id字段
models.py
1
2
3
4
5
6
7
class
Gender(models.Model):
gender
=
models.CharField(max_length
=
2
)
class
User(models.Model):
name
=
models.CharField(max_length
=
10
)
age
=
models.IntegerField()
gender
=
models.ForeignKey(Gender)
cmd
1
2
3
4
5
6
7
|
class Gender(models.Model): gender = models.CharField(max_length = 2 ) class User(models.Model): name = models.CharField(max_length = 10 ) age = models.IntegerField() gender = models.ForeignKey(Gender) |
Django--path > python manager.py makemigrations
Django--path > python manager.py migrate
db--gender表
db--user表
1.2 连接不是id的字段
外键列,默认是用id来连接,这个字段名称自动改为“xx_id”列,如果使用某个字段连接,需要参数to-field:"连接的字段";
models.py
1
2
3
4
5
6
7
|
class Salary(models.Model): name = models.CharField(max_length = 10 ,unique = True ) salary = models.IntegerField() class User(models.Model): name = models.CharField(max_length = 10 ) age = models.IntegerField() salary = models.ForeignKey(Salary,to_field = "name" ) |
db--salary(薪资)表
db--user表
2、多对多--ManyToManyField
models.py
1
2
3
4
5
6
|
class Hobby(models.Model): hobby = models.CharField(max_length = 10 ) class User(models.Model): name = models.CharField(max_length = 10 ) age = models.IntegerField() hobby = models.ManyToManyField(Hobby) |
db--hobby(爱好)表
db--user表
user表中并没有创建hobby列,而是新建了一张表,记录了他们的对应关系。
db--user_hobby
3、一对一--OneToOneField
外键的表每行只能被选择一次
models.py
1
2
3
4
5
6
7
8
|
class Salary(models.Model): name = models.CharField(max_length = 10 ,unique = True ) salary = models.IntegerField() class User(models.Model): name = models.CharField(max_length = 10 ) age = models.IntegerField() salary = models.OneToOneField(Salary,to_field = "name" ) |
Django--models连表构建的更多相关文章
- Django models多表操作
title: Django models多表操作 tags: Django --- 多表操作 单独创建第三张表的情况 推荐使用的是使用values/value_list,selet_related的方 ...
- Django models 单表查询
从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet 1. 查看Django QuerySet执行的SQL .query.__str__()或 .query属性打印执行的sql语句 ...
- django models的点查询/跨表查询/双下划线查询
django models 在日常的编程中,我们需要建立数据库模型 而往往会用到表与表之间的关系,这就比单表取数据要复杂一些 在多表之间发生关系的情形下,我们如何利用models提供的API的特性获得 ...
- 第三百八十节,Django+Xadmin打造上线标准的在线教育平台—将所有app下的models数据库表注册到xadmin后台管理
第三百八十节,Django+Xadmin打造上线标准的在线教育平台—将所有app下的models数据库表注册到xadmin后台管理 将一个app下的models数据库表注册到xadmin后台管理 重点 ...
- day20 Django Models 操作,多表,多对多
1 Django models 获取数据的三种方式: 实践: viwes def business(request): v1 = models.Business.objects.all() v2 = ...
- Django之form表单详解
构建一个表单 假设你想在你的网站上创建一个简单的表单,以获得用户的名字.你需要类似这样的模板: <form action="/your-name/" method=" ...
- url路由、模板语言、ajax、用django框架创建表
1.后台管理的左侧菜单,默认只有第一个页签下面的选项是显示的,点了别的页签再显示别的页签下面的选项,问题是:点了任何菜单的选项后,左侧菜单又成了第一个页签的选项显示,别的页签隐藏,也就是左侧的菜单刷新 ...
- django models数据类型
Django Models的数据类型 AutoField IntegerField BooleanField true/false CharField maxlength,必填 TextField C ...
- django models 类型整理 version:1.8.3
django models 类型整理 version:1.8.3 网上百度到的最上面的一篇已经是11年的了,django变化很大,现在把1.8.3版的models类型大致整理了下贴出来 普通键部分 F ...
随机推荐
- http 请求类
1.httpclient请求类 代理demo:http://hc.apache.org/httpcomponents-client-4.3.x/httpclient/examples/org/apac ...
- ldr和adr在使用标号表达式作为操作数的区别
ARM汇编有ldr指令以及ldr.adr伪指令,他门都可以将标号表达式作为操作数,下面通过分析一段代码以及对应的反汇编结果来说明它们的区别. ldr r0, _start adr r0 ...
- css强制换行和超出隐藏实现
一.强制换行1 word-break: break-all; 只对英文起作用,以字母作为换行依据. 2 word-wrap: break-word; 只对英文起作用,以单词作为换行依据. 3 ...
- AWVS漏洞测试-03节-添加扫描项目
http://localhost:9660 我们要扫描这个页面 点击左上角的New Scan,在Scan Single哪里输入要扫描的网站地址,可以是本地地址 然后选择下一步 Next 这里我们可以配 ...
- python在windows平台的pip安装package时的编译问题
在安装pcapy时,出现以下错误: building 'pcapy' extension error: Microsoft Visual C++ 9.0 is required (Unable to ...
- Java IO--压缩流
压缩流: 压缩流的实现: zipEntry: 在实例化ZipEntry的时候,要设置名称,此名称实际上就是压缩文件中的每一个元素的名称. ZipOutputStream: import java.io ...
- javascript 的一些理解和随笔
一.iframe里面的页面调用父窗口,左右窗口js函数的方法 iframe里面的页面调用父窗口,左右窗口js函数的方法 实现iframe内部页面直接调用该iframe所属父窗口自定义函数的方法. 比如 ...
- [Core Javascirpt] Basic Metaprogramming: Dynamic Method
Somehow it looks like reflect in Java. For example: We define an mothod on the Object, it called def ...
- 如何优雅的在MFC中使用cvSetMouseCallback?
MFC与opencv的cvSetMouseCallback用起来感觉很不兼容. 大部分时候,用cvSetMouseCallback也许只是为了获取一个矩形框,或者绘制一个点,或者其它什么简易的图形,通 ...
- 像table一样布局div
原文:http://www.456bereastreet.com/archive/200405/equal_height_boxes_with_css/ 下面是我翻译的内容,是根据我对文章的理解意译的 ...