一对多表之间的查询:

  1. class userInfo(models.Model):
  2. name = models.CharField(max_length=50)
  3. password = models.CharField(max_length=50)
  4. email = models.EmailField()
  5. user_type = models.ForeignKey('userType')
  6. class userType(models.Model):
  7. 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

总结:对象__列名__方法 = ' '

多对多表之间查询:

  1. class userInfo(models.Model):
  2. name = models.CharField(max_length=50)
  3. password = models.CharField(max_length=50)
  4. email = models.EmailField()
  5. user_type = models.ForeignKey('userType')
  6.  
  7. class userGroup(models.Model):
  8. group = models.CharField(max_length=50)
  9. user = models.ManyToManyField('userInfo')

1.建立关系

  1.    t3 = userType.objects.get(name='supper')
  2. t4 = userType.objects.get(name='nomal')
  3. u1 = userInfo.objects.create(name='yj1',password='',email='1@qq.com',user_type=t3)
  4. u2 = userInfo.objects.create(name='yj1',password='',email='1@qq.com',user_type=t4)
  5. groupObjA = userGroup.objects.create(group='HOSTA')
  6. groupObjA.user.add(u1)
  7. groupObjB = userGroup.objects.create(group='HOSTB')
  8. 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多表操作的更多相关文章

  1. Django之model联表:一对多、跨表操作,联表查询

    表结构概述 model.py : class Something(models.Model): name = models.CharField(max_length=32) class UserTyp ...

  2. python——Django(ORM连表操作)

    千呼万唤始出来~~~当当当,终于系统讲了django的ORM操作啦!!!这里记录的是django操作数据库表一对多.多对多的表创建及操作.对于操作,我们只记录连表相关的内容,介绍增加数据和查找数据,因 ...

  3. Django模型层-多表操作

    多表操作 一.创建模型 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是 ...

  4. Django模型层-单表操作

    ORM介绍 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的 ...

  5. Django之django模型层一单表操作

    一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人 ...

  6. python第一百一十一天 --Django 6 model 的相关操作

    创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行数据库操作 import MySQLdb def GetList(sql): db ...

  7. django基础 -- 6. 多表操作

    一.多表的创建 from django.db import models # Create your models here. class Author(models.Model): id = mod ...

  8. Django day07 (二)单表操作

    单表操作 -mysql数据库:settings里配置: DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME ...

  9. Django进阶Model篇—数据库操作(ORM)

    一.数据库配置 django 默认支持sqlite.mysql.oracle.postgresql数据库,像db2和sqlserver之类的数据库需要第三方的支持,具体详见https://docs.d ...

随机推荐

  1. JS判断元素是否在数组内

    //判断元素是否在数组内 function contains(arr, obj) { var i = arr.length; while (i--) { if (arr[i] === obj) { r ...

  2. Qt做发布版,解决声音和图片、中文字体乱码问题(需要在main里写上QApplication::addLibraryPath("./plugins")才能加载图片,有图片,很清楚)

    前些天做Qt发布版,发现居然不显示图片,后来才发现原来还有图片的库没加!找找吧,去qt的安装包,我装在了F盘,在F盘F:/QT/qt/plugins,找到了plugins,这里面有个 imagefor ...

  3. Flutter - BottomNavigationBar底部导航栏切换后,状态丢失。底部

    import 'package:flutter/material.dart'; import './pages/home_page.dart'; import './pages/book_page.d ...

  4. 编码原则 之 Persistence Ignorance

    原文 The principle of Persistence Ignorance (PI) holds that classes modeling the business domain in a ...

  5. Linux配置中文输入法(搜狗输入法)

    一.基础知识 在原生ubuntu14.04英文环境系统中只有IBus拼音,真的好难用.由于搜狗输入法确实比Linux系统下其它的中文输入法都要好用得多,所以我决定在我的Ubuntu 14.04系统中安 ...

  6. JQuery学习二-字典操作

    1. 数组中添加map var arr = []; var key = 'Jeremy'; var value = '!!!!' arr.push({ 'key': key, 'value': val ...

  7. 实现Python与STM32通信

    断断续续学了几周Stm32后,突然想实现上位机和下位机的通信,恰好自己学过一点python,便想通过python实现通信. 在网上看见python库pyserial可以实现此功能,便去官网找了一下 , ...

  8. 查漏补缺之——Java多线程

    复习面试题中遇到锁的内容当时大一学习的时候感觉懵懂,现在重新复习一下. 1.1多线程 1.1.1线程 1.什么是线程 线程是程序执行的一条路径,一个进程中包含多条进程 2.并行与并发 并行是两个任务同 ...

  9. C#实现基于ffmpeg加虹软的人脸识别

    关于人脸识别 目前的人脸识别已经相对成熟,有各种收费免费的商业方案和开源方案,其中OpenCV很早就支持了人脸识别,在我选择人脸 识别开发库时,也横向对比了三种库,包括在线识别的百度.开源的OpenC ...

  10. 简单的class及运算符重载

    #include <iostream> #include <vector> #include <algorithm> using namespace std; cl ...