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. redis书籍

    redis中文官网命令网址:http://doc.redisfans.com/ redis英文官网命令网址:https://redis.io/commands redis书籍 由 Karl Segui ...

  2. Statement对象

    Statement 对象 创建 Statement 对象 在你准备使用 Statement 对象执行 SQL 语句之前,你需要使用 Connection 对象的 createStatement() 方 ...

  3. php 单向散列加密

    1.加密文件 <?php //sha1_en.php header("content-type:text/html;charset=utf-8"); $str = " ...

  4. etcd使用

    下载: https://github.com/etcd-io/etcd/releases/tag/v3.3.13 tar -zxvf   etcd-v3.3.13-linux-amd64.tar.gz ...

  5. 每日算法之三十四:Multiply Strings

    大数相乘,分别都是用字符串表示的两个大数.求相乘之后的结果表示. 首先我们应该考虑一下測试用例会有哪些,先准备測试用例对防御性编程会有比較大的帮助.可以考虑一些极端情况.有以下几种用例: 1)&quo ...

  6. log4j:ERROR Could not read configuration file [log4j.properties]

    遇到这个错误,程序能够正常运行,log4j.properties也在classpath中,后来在网上查了资料,把下面这个语句去掉就好啦. PropertyConfigurator.configure( ...

  7. maven与sbt修改国内镜像

    一.idea中的maven 1.打开IntelliJ IDEA->Settings ->Build, Execution, Deployment -> Build Tools > ...

  8. 帮助你构建云服务的开源平台:openstack

    from:http://os.51cto.com/art/201205/336386_all.htm 概念架构 3-5 OpenStack Compute服务架构 点评:从openstack的能力来看 ...

  9. Django-2.2.1版本关于无法使用makemigrations的错误

    报错 django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0. ...

  10. 2019-9-2-dotnet-命名管道名字长度限制

    title author date CreateTime categories dotnet 命名管道名字长度限制 lindexi 2019-09-02 11:54:50 +0800 2019-09- ...