models.py示例
class Book(models.Model):
nid=models.AutoField(primary_key=True)
title=models.CharField(max_length=)
# 书籍与出版社: 一对多
publisher=models.ForeignKey(to="Publish",related_name="bookList")
# 书籍与作者: 多对多
authors=models.ManyToManyField("Author") class Publish(models.Model):
name=models.CharField(max_length=) class Author(models.Model):
name=models.CharField(max_length=) class AuthorDetail(models.Model):
addr=models.CharField(max_length=)
author=models.OneToOneField("Author")
单表查收
models.Book.obejcts.all()       #   QuerySet    []
models.Book.obejcts.filter(nid__gt=,nid__lt=) # QuerySet []
models.Book.obejcts.get() # model对象
models.Book.obejcts.values() # QuerySet [{},{}]
models.Book.obejcts.values_list()
models.Book.obejcts.exclude()
models.Book.obejcts.all().first()
models.Book.obejcts.all().last()
models.Book.obejcts.all().orderby()
models.Book.obejcts.all().reverse()
models.Book.obejcts.values("price").distinct() #去重不要带索引,索引本身是唯一的
models.Book.obejcts.all().count()
models.Book.obejcts.all().exist() ---- 双下划线:
models.Book.obejcts.filter(nid__gt=)
models.Book.obejcts.filter(price__in=[,,]) 支持链式操作:
models.Book.obejcts.all().filter().orderby("id").count()
models.Book.obejcts.all().get().orderby("id").count()
跨表查询

基于对象 类似于SQL语句的子查询

(1) 查询Linux这本书的出版社名称和作者名字   属于正向查询  按关联字段

book_obj=models.Book.obejcts.get(title="linux")
book_obj.publisher.name authors_list=book_obj.authors.all()
for author in authors_list:
print(author.name)

(2) 人民出版社出版过的所有书籍名称   属于反向查询  if 设置related_name,那么related_name的值,没有设置,按表明_set

 publish_obj=models.Publish.obejcts.filter(name="人民出版社").first()
book_list=publish_obj.bookList.all()
for book in book_list:
print(book.title)

(3) alex 出版社过得所有书籍的名称    属于反向查询 if 设置related_name,那么related_name的值,没有设置,按表明_set

 alex=models.Author.obejcts.get(name="alex")
book_list=alex.book_set.all()
for book in book_list:
print(book.title)

(4) 作者alex的所在地址  正向查询 按字段  反向查询 按表名

   alex=models.Author.obejcts.get(name="alex")
alex.authordetail.addr
基于QuerySet

双下划线:类似于inner join   正向查询:按字段     反向查询:按表名    key:  1 过滤条件  2 查询结果

(1) 查询Linux这本书的出版社名称和作者名字   属于正向查询  按关联字段

models.Book.obejcts.filter(title="linux").values("publisher__name") # [{"publisher__name":"人民出版社"}]
models.Book.obejcts.filter(title="linux").values("authors__name") #

(2) 人民出版社出版过的所有书籍名称

 models.Book.obejcts.filter(publisher__name="人民出版社").values("title")
models.Publish.obejcts.filter(name="人民出版社").values("book__title")

(3) alex 出版社过得所有书籍的名称

models.Book.obejcts.filter(authors__name="alex").values("title")          
models.Author.obejcts.filter(name="alex").values("book__title")

Django-ORM查询api的更多相关文章

  1. django orm查询和后端缓存的使用

    django orm 查询 1 字段后(db_column='age') (null=True)#表示数据库里面的该字段数据可以为空 (blank=True)#表示前端表单提交的时候可以为空 (db_ ...

  2. Django ORM 查询管理器

    Django ORM 查询管理器 ORM 查询管理器 对于 ORM 定义: 对象关系映射, Object Relational Mapping, ORM, 是一种程序设计技术,用于实现面向对象编程语言 ...

  3. Django 源码小剖: Django ORM 查询管理器

    ORM 查询管理器 对于 ORM 定义: 对象关系映射, Object Relational Mapping, ORM, 是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从 ...

  4. Django ORM 查询操作

    queryset中支持链式操作 book=Book.objects.all().order_by('-nid').first() 只要返回的是queryset对象就可以调用其他的方法,直到返回的是对象 ...

  5. Django(ORM查询2)

    day70 ORM训练专题 :http://www.cnblogs.com/liwenzhou/articles/8337352.html 内容回顾     1. ORM         1. ORM ...

  6. django -- ORM查询

    前戏 在我们之前操作ORM中,你也许是启动Django项目,通过地址访问固定的函数,或者在pycharm里的python console里执行,第一种比较麻烦,而且每次都要启动项目,写路由,第二种虽然 ...

  7. Python - Django - ORM 查询方法

    models.py: from django.db import models class Human(models.Model): id = models.AutoField(primary_key ...

  8. Django(ORM查询联系题)

    day70 练习题:http://www.cnblogs.com/liwenzhou/articles/8337352.html import os import sys if __name__ == ...

  9. Django(ORM查询1)

    day69 参考:http://www.cnblogs.com/liwenzhou/p/8660826.html 在Python脚本中调用Django环境 orm1.py import os if _ ...

  10. Django ORM 查询

    过滤器 过滤器 作用 all() 查出所有行 filter() 可以添加过滤条件 order_by() 查出所有数据,如果有参数则按参数排序,参数是字符串 ,如:"-username&quo ...

随机推荐

  1. LeetCode——Single Number

    Description: Given an array of integers, every element appears twice except for one. Find that singl ...

  2. replace方法的深入理解

    “abc”.replace(/b/, "$`") // $`将正则匹配到的字符替换为匹配到的字符左边的字符 aac “abc”.replace(/b/, "$'" ...

  3. 运行npm install出现警告

    如下: 解决: fsevent是mac osx系统的,你是在win或者Linux下使用了 所以会有警告,忽略即可

  4. Cordova 3.0 初步使用

    主要参考 http://docs.phonegap.com/en/3.0.0/guide_cli_index.md.html#The%20Command-line%20Interface Cordov ...

  5. thinkphp --- 写入日志

    在开发过程中,对于一些参数,不好直接输入或者打印调试,特别是在微信开发过程中,这个时候,通过日志来查看信息就显得格外重要. 下面是在TP3.2.3框架中,写入日志的方法: public functio ...

  6. 宝塔面板快速开启https服务

    最近在做小程序开发,急需要一个https的域名,首先我的域名是阿里云的,服务器是腾讯云的,操作都一样: 无论阿里云还是腾讯云,配置SSL是针对服务器的,所以首先是要去申请 腾讯/阿里云服务器的SSL( ...

  7. 微信小程序 --- if/else条件渲染

    if 条件渲染:当为真的时候显示,当为假的时候隐藏: else 条件渲染:当为真的时候隐藏,当为假的时候显示: <view wx:if="{{true}}">{{tex ...

  8. C++和C#的思考

    从2011年从业至今已经写了7年C++了,而C#.go语言虽然早有涉猎,但直到最近才开始思考语言的发展和工程之间的关系. C++ 更容易写出高内聚代码使用指针做原地内存操作直接堆栈控制,减少内存分配, ...

  9. Spring boot官方文档学习(一)

    个人说明:本文内容都是从为知笔记上复制过来的,样式难免走样,以后再修改吧.另外,本文可以看作官方文档的选择性的翻译(大部分),以及个人使用经验及问题. 其他说明:如果对Spring Boot没有概念, ...

  10. spring boot 打包方式 spring boot 整合mybaits REST services

    <build> <sourceDirectory>src/main/java</sourceDirectory> <plugins> <plugi ...