需求

models多表(一对多、多对多、一对一)的构建

速查

1、一对多

1
2
3
class User(models.Model):
    name = models.CharField(max_length=10)
    gender = models.ForeignKey(外键表名,to_field="连接的字段")

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

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连表构建的更多相关文章

  1. Django models多表操作

    title: Django models多表操作 tags: Django --- 多表操作 单独创建第三张表的情况 推荐使用的是使用values/value_list,selet_related的方 ...

  2. Django models 单表查询

    从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet 1. 查看Django QuerySet执行的SQL .query.__str__()或 .query属性打印执行的sql语句 ...

  3. django models的点查询/跨表查询/双下划线查询

    django models 在日常的编程中,我们需要建立数据库模型 而往往会用到表与表之间的关系,这就比单表取数据要复杂一些 在多表之间发生关系的情形下,我们如何利用models提供的API的特性获得 ...

  4. 第三百八十节,Django+Xadmin打造上线标准的在线教育平台—将所有app下的models数据库表注册到xadmin后台管理

    第三百八十节,Django+Xadmin打造上线标准的在线教育平台—将所有app下的models数据库表注册到xadmin后台管理 将一个app下的models数据库表注册到xadmin后台管理 重点 ...

  5. day20 Django Models 操作,多表,多对多

    1 Django models 获取数据的三种方式: 实践: viwes def business(request): v1 = models.Business.objects.all() v2 = ...

  6. Django之form表单详解

    构建一个表单 假设你想在你的网站上创建一个简单的表单,以获得用户的名字.你需要类似这样的模板: <form action="/your-name/" method=" ...

  7. url路由、模板语言、ajax、用django框架创建表

    1.后台管理的左侧菜单,默认只有第一个页签下面的选项是显示的,点了别的页签再显示别的页签下面的选项,问题是:点了任何菜单的选项后,左侧菜单又成了第一个页签的选项显示,别的页签隐藏,也就是左侧的菜单刷新 ...

  8. django models数据类型

    Django Models的数据类型 AutoField IntegerField BooleanField true/false CharField maxlength,必填 TextField C ...

  9. django models 类型整理 version:1.8.3

    django models 类型整理 version:1.8.3 网上百度到的最上面的一篇已经是11年的了,django变化很大,现在把1.8.3版的models类型大致整理了下贴出来 普通键部分 F ...

随机推荐

  1. 解决.Net 4.0 A potentially dangerous Request.Form value was detected from the client 异常

    在web.config中加入 <httpRuntime maxRequestLength="22000" executionTimeout="43200" ...

  2. SQL获取本周销售总数

    select sum("NUMBER") as WEEK_NUMBER, COMPANY_CODE, PROJECT_CODE from D_VISIT WHERE "D ...

  3. 《STL系列》之vector原理及实现

    最近忙得蛋疼,但还是想写点属于自己的东西.也不知道写点啥,最后决定试着自己实现STL中常用的几个集合,一来加深自己对STL的理解,二来看看自己是否有这个能力实现.实现目标就是:1能和STL兼容:2最大 ...

  4. Markdown学习语法的记录

    标题示例 === 标题示例 ---- #标题示例 ##标题示例 ###标题示例 >引用示例 >>引用示例 >>> 引用示例 _斜体示例_ *斜体示例* __粗体示例 ...

  5. TaskHosting - 开发桌面工具原来还可以这么简单

    由来 对于喜欢开发的我经常会写一些小工具,这些小工具多以功能为主,不要求漂亮.个性化的UI.但起码要保证使用方便,因此最基本的功能要有: GUI(图片用户界面) 程序配置的保存与读取(让用户在GUI上 ...

  6. 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL[转]

    使用MySQL Migration Toolkit快速将Oracle数据导入MySQL上来先说点废话本人最近在学习一些数据库方面的知识,之前接触过Oracle和MySQL,最近又很流行MongoDB非 ...

  7. windbg----as、$u0(固定别名、自定义别名)

    固定别名($u0~$u9) 有10个固定别名.他们是$u0, $u1, ..., $u9.他们的等价字符串可以是不包含ENTER键的任意字符串.使用r (Registers)命令为固定别明指定等价字符 ...

  8. “合规性”是考核IT运维的重要指标

    ITSM的绩效考核向来是一个令人头疼的问题,有时就像一团乱麻,既无章可循,又无从下手.其实,只要掌握正确的思想方法,就能拨云见日.“斩乱麻”需“快刀”,“合规性考核”就是斩ITSM绩效考核这团乱麻的快 ...

  9. 彩色的Shell

    我常在命令行下工作,以前老被同事说"你整天在那个黑窗口上倒腾什么?" 现在这个问题变成了"你这个花花绿绿的窗口是什么东西?" 其实都是同一个东西:一个兼容于xterm的终端窗口,要么是PuTTY/Ki ...

  10. 尝试在tensorflow上运行facenet

    上一篇装好了tensorflow的运行环境,开始尝试运行一些实例代码,在github上找到了一个tensorflow实现的facenet的代码,还是遇到了很多坑! 坚持看完,有重要总结! 代码:htt ...