django之model多表操作
一对多表之间的查询:
class userInfo(models.Model):
name = models.CharField(max_length=50)
password = models.CharField(max_length=50)
email = models.EmailField()
user_type = models.ForeignKey('userType')
class userType(models.Model):
name = models.CharField(max_length=50)
1.all,get,filter
·all:所有数据(序列)
·get:单挑数据,是一个对象(封装一行多列数据)
·filter:序列
eg: 取id>5
userInfo.objects.filter(id__gt = 5)
eg:userType大于5的所有用户信息
userInfo.objects.filter(user_type__id__gt=5 )
说明:user_type就是userType对象
eg:userType大名字包含a的所有用户信息
userInfo.objects.filter(user_type__name__contains='a' )
说明:user_type就是userType对象
eg:查看用户类型等于超级管理员的所有用户
userInfo.objects.filter(user_type__name = "超级管理员")==select * from userInfo xxx
userInfo.objects.filter(user_type__name = "超级管理员").values('username') == select username from xxx
总结:对象__列名__方法 = ' '
多对多表之间查询:
class userInfo(models.Model):
name = models.CharField(max_length=50)
password = models.CharField(max_length=50)
email = models.EmailField()
user_type = models.ForeignKey('userType') class userGroup(models.Model):
group = models.CharField(max_length=50)
user = models.ManyToManyField('userInfo')
1.建立关系
t3 = userType.objects.get(name='supper')
t4 = userType.objects.get(name='nomal')
u1 = userInfo.objects.create(name='yj1',password='',email='1@qq.com',user_type=t3)
u2 = userInfo.objects.create(name='yj1',password='',email='1@qq.com',user_type=t4)
groupObjA = userGroup.objects.create(group='HOSTA')
groupObjA.user.add(u1)
groupObjB = userGroup.objects.create(group='HOSTB')
groupObjB.user.add(u2)
分析: 两表多对多实质上就是用一个新表记录其关系, groupObjA.user.add(u1)可以理解为先执行groupObjA.user,即在表中插入groupObjA的id;再执行.add(u1),即插入u1的id
2.两种建立方式
1)groupObjA.user.add(u1) == groupObjA有多对多字段
2) u1.userGroup_set.add(groupObjA) == u1无多对多字段
django之model多表操作的更多相关文章
- Django之model联表:一对多、跨表操作,联表查询
表结构概述 model.py : class Something(models.Model): name = models.CharField(max_length=32) class UserTyp ...
- python——Django(ORM连表操作)
千呼万唤始出来~~~当当当,终于系统讲了django的ORM操作啦!!!这里记录的是django操作数据库表一对多.多对多的表创建及操作.对于操作,我们只记录连表相关的内容,介绍增加数据和查找数据,因 ...
- Django模型层-多表操作
多表操作 一.创建模型 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是 ...
- Django模型层-单表操作
ORM介绍 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的 ...
- Django之django模型层一单表操作
一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人 ...
- python第一百一十一天 --Django 6 model 的相关操作
创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行数据库操作 import MySQLdb def GetList(sql): db ...
- django基础 -- 6. 多表操作
一.多表的创建 from django.db import models # Create your models here. class Author(models.Model): id = mod ...
- Django day07 (二)单表操作
单表操作 -mysql数据库:settings里配置: DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME ...
- Django进阶Model篇—数据库操作(ORM)
一.数据库配置 django 默认支持sqlite.mysql.oracle.postgresql数据库,像db2和sqlserver之类的数据库需要第三方的支持,具体详见https://docs.d ...
随机推荐
- Docker Macvlan 介绍 or 工作原理
Docker Macvlan Network Macvlan Network:属于Docker的网络驱动. Macvlan Network:Docker主机网卡接口逻辑上分为多个子接口,每个子接口标识 ...
- Linux sar工具安装使用
使用sar Sar是后台进程sadc的前端显示工具,安装名为“sysstat”的包后,sadc就会自动从内核收集报告并保存. 安装sar [root@localhost ~]# yum insta ...
- miui获取完整root
1.先解锁BL锁 需要在miui官网申请,下载相关软件,申请后下载软件,提示需要过xx小时才能解锁(我是72小时) 2.解开BL锁后,在系统设置里开启root权限 3.开启root权限后,发现/sys ...
- python 排序算法
冒泡排序: 一. 冒泡排序的定义 冒泡排序(英语:Bubble Sort)是一种简单的排序算法.它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.遍历数列的工作是重复地进 ...
- HTTP长连接、短连接究竟是什么?
1. HTTP协议与TCP/IP协议的关系 HTTP的长连接和短连接本质上是TCP长连接和短连接.HTTP属于应用层协议,在传输层使用TCP协议,在网络层使用IP协议. IP协议主要解决网络路由和寻址 ...
- Java中static的用法解析
知识点1.static关键字a.可以修饰变量,方法,代码块b.修饰的变量和方法可以使用类名.变量名/类名.方法名调用c.static修饰的资源为静态资源,在类加载的时候执行d.在静态方法中只能调用静态 ...
- 深入分析Parquet列式存储格式【转】
Parquet是面向分析型业务的列式存储格式,由Twitter和Cloudera合作开发,2015年5月从Apache的孵化器里毕业成为Apache顶级项目,最新的版本是1.8.0. 列式存储 列式存 ...
- 补充一下 sizeof
sizeof是一个运算符,给出某个类型或变量在内存中所占据的字节数 sizeof(int) //告诉你int占据几个字节 sizeof(i) //告诉你i这个变量占据几个字节 注:sizeof是静态运 ...
- Go语言开发Prometheus Exporter示例
一.Prometheus中的基本概念 Prometheus将所有数据存储为时间序列,这里先来了解一下prometheus中的一些基本概念 指标名和标签每个时间序列都由指标名和一组键值对(也称为标签)唯 ...
- 【分布式搜索引擎】Elasticsearch分布式架构原理
一.相关概念介绍 1)集群(cluster) 一个集群(cluster)由一个或多个节点组成. 这些节点具有相同的cluster.name,它们协同工作,分享数据和负载.当加入新的节点或者删除一个节点 ...