django 表的理解

好处:设计的好,会清晰,易于理解和维护,后期开发事半功倍,一目了然.

1. 一对一的表,两表的属性实际上完全可以合并成一个表,共用一个主键即可;
2. 一对多的表,可以设中间关联表,也可以将关联表并入“多”这头;若设独立关联表,则可引入“多”这头的主键作为其主键,也可另立主键并将“一”和“多”两表的主键作为关联表的外键;
3. 多对多的表,则必须设中间关联表,关联表设独立主键,并引入两个“多”头的表的主键作为关联表的外键。 4. 能用1对1的,就不用1对多;能用1对多的,就不用多对多,往简单化方向靠;
5. 能当属性处理的,尽量当属性,而不是当实体处理去另立新表,这样可使问题简化。
6. 把意义相近联系紧密的属性放在一张表内,而不是拆在多张表中。

基本原则

一对一:一般用于某张表的补充,比如用户基本信息是一张表,但并非每一个用户都需要有登录的权限,不需要记录用户名和密码,此时,合理的做法就是新建一张记录登录信息的表,与用户信息进行一对一的关联,可以方便的从子表查询母表信息或反向查询

外键:有很多的应用场景,比如每个员工归属于一个部门,那么就可以让员工表的部门字段与部门表进行一对多关联,可以查询到一个员工归属于哪个部门,也可反向查出某一部门有哪些员工

多对多:如很多公司,一台服务器可能会有多种用途,归属于多个产品线当中,那么服务器与产品线之间就可以做成对多对,多对多在A表添加manytomany字段或者从B表添加,效果一致

应用场景

三种关系解读:

ForeignKey:多对一

ManyToManyField:多对多

OneToOneField:一对一

注:要求第一个参数是一个模型类,需要使用verbose_name才能指定自述名

class Category(models.Model):
'''
文章分类
'''
name = models.CharField(max_length=20,verbose_name='文章类别')
number = models.IntegerField(default=1,verbose_name='分类数目') class Tags(models.Model):
'''
文章标签
'''
name = models.CharField(max_length=20,verbose_name='文章标签')
number = models.IntegerField(default=1, verbose_name='标签数目') class Blog(models.Model):
'''
博客
'''
title = models.CharField(max_length=100,verbose_name=u'标题')
content = models.TextField(default='',verbose_name=u'正文')
create_time = models.DateTimeField(default=timezone.now,verbose_name=u'创建时间')
modify_time = models.DateTimeField(auto_now=True,verbose_name=u'修改时间')
click_nums = models.IntegerField(default=0,verbose_name=u'点击量')
category = models.ForeignKey(Category,on_delete=models.CASCADE,verbose_name=u'文章类别')
tags = models.ManyToManyField(Tags,verbose_name=u'文章标签') class Comment(models.Model):
'''
评论
'''
name = models.CharField(max_length=20,default=u'佚名',verbose_name=u'姓名')
content = models.TextField(verbose_name=u'内容')
create_time = models.DateTimeField(auto_now_add=True,verbose_name=u'创建时间')
blog = models.ForeignKey(Blog,verbose_name=u'博客') ##博客与文章类别是多对一;博客与标签是多对多;博客与评论是多对一

示例

class user(model.Model):
address=models.CharField()
phone=models.Integer() class host(Models.model):
place=models.OneToOneField(user) 这里创建了一个’user’数据库,里面有一些常用的字段,那接下来我想在已有基础上新增’host’数据库,而且不想将已有的字段赋值到’host’模型中,那我们可以添加OneToOneField字段,指向’user’. (在这里我们应该使用典型的继承,它隐含了一个一对一的关系)

一对一示例

django 中models表的多对一,多对多的理解的更多相关文章

  1. Django开发之路 二(django的models表查询)

    django的models表查询 一.单表查询 (1) all(): 查询所有结果 # 返回的QuerySet类型 (2) filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 #返 ...

  2. Django中的表单

    目录 表单 Django中的表单 用表单验证数据 自定义验证 表单 HTML中的表单是用来提交数据给服务器的,不管后台服务器用的是 Django  还是 PHP还是JSP还是其他语言.只要把 inpu ...

  3. Django中多表的增删改查操作及聚合查询、F、Q查询

    一.创建表 创建四个表:书籍,出版社,作者,作者详细信息 四个表之间关系:书籍和作者多对多,作者和作者详细信息一对一,出版社和书籍一对多 创建一对一的关系:OneToOne("要绑定关系的表 ...

  4. Django中的表关系实现及操作

    表关系的实现   预备知识 ORM的正向操作和反向操作: 1.正向操作:一个模型中定义了一个外键,通过该模型对该外键操作的操作叫做正向操作. 2.反向操作:被外键所关联的模型,通过该模型对外键所在模型 ...

  5. Django中ORM表的创建以及基本增删改查

    Django作为重量级的Python web框架,在做项目时肯定少不了与数据库打交道,编程人员对数据库的语法简单的还行,但过多的数据库语句不是编程人员的重点对象.因此用ORM来操作数据库相当快捷.今天 ...

  6. django中models阅读笔记

    一.使用数据库需要设置settings.py文件. DATABASES = { 'default': { 'ENGINE': 'django.db.backends.', # Add 'postgre ...

  7. Django中models定义的choices字典使用get_FooName_display()在页面中显示值

    问题 在django的models.py 中,我们定义了一些choices的元组,类似一些字典值,一般都是下拉框或者单多选框,例如 0对应男 1对应女等等 看下例子: class Area(model ...

  8. django中form表单的提交:

    一,关于表单: 表单在百度百科的解释:   表单在网页中主要负责数据采集功能.一个表单有三个基本组成部分: 表单标签:这里面包含了处理表单数据所用CGI程序的URL以及数据提交到服务器的方法. 表单域 ...

  9. Django中多表查询思路

    需求: 1.有一张文章表和一张评论表 2.两张表的关系是一对多 3.规则:若是有新评论,则将对应的文章置顶,若是有新文章则将新文章置顶. 思路: 在文章表中增加一个最后评论时间的字段.然后采用分组排序 ...

随机推荐

  1. UVA1204 Fun Game

    Fun Game https://odzkskevi.qnssl.com/8d698323a1e07d605cdeea708ee8a01d?v=1508703139 [题解] 不难发现如果一个串的原串 ...

  2. 七.RBM受限玻尔兹曼机

    1.受限玻尔兹曼机   玻尔兹曼机是一大类的神经网络模型,但是在实际应用中使用最多的则是受限玻尔兹曼机(RBM). 受限玻尔兹曼机(RBM)是一个随机神经网络(即当网络的神经元节点被激活时会有随机行为 ...

  3. Python单元测试浅析

    测试的意义   人们针对一个具体问题,通过分析和设计,最后用编程语言写出了一个程序,如果它通过了语言解释器(编译器)的检查,可以运行了,那么下一步的工作就是设法确认它确实满足了我们需求.这篇文章就是讨 ...

  4. 学习JDK1.8集合源码之--LinkedHashSet

    1. LinkedHashSet简介 LinkedHashSet继承自HashSet,故拥有HashSet的全部API,LinkedHashSet内部实现简单,核心参数和方法都继承自HashSet,只 ...

  5. js实现动态计数效果

    下面附有数字图片和数字边框图 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  6. PHP闭包实现函数的自调用实现递归

    根据pathinfo访问对应得controller,如ip:port/home/index/index则会访问home目录下的IndexController的index方法:如果不指定pathinfo ...

  7. Codeforces 404B

    毫无疑问这题不是难题,但是这种题目最让人纠结 打心里对这种题目就比较害怕,果然,各种WE 这里贴上代码,用Python写的,比较偷懒: def cur_pos(a, d): if 0 <= d ...

  8. fedora下eclipse安装tomcat插件

    首先下载tomcat插件: http://www.eclipsetotale.com/tomcatPlugin.html,下载最新的3.3版本: 由于我的eclipse是通过yum自动安装的,因此ec ...

  9. 【OI】倍增求LCA

    ╭(′▽`)╯ 总之,我们都知道lca是啥,不需要任何基础也能想出来怎么用最暴力的方法求LCA,也就是深度深的点先跳到深度浅的点的同一深度,然后一起向上一步步跳.这样显然太慢了! 所以我们要用倍增,倍 ...

  10. Directx11教程(14) D3D11管线(3)

    原文:Directx11教程(14) D3D11管线(3)       现在我们开始学习一些CP(command processor)的知识.参考资料: http://fgiesen.wordpres ...