一 必知必会13条:

  返回对象列表的:

    1.all() :查所有

    2.filter() :查一行

    3.exclude():排除(里面可以写条件,意思除了这个条件的所有)

    4.order_by():默认升序(可以写条件,加符号为降序)

    5.reverse() :它是对已经排好序的基础上进行翻转。

    6.distinct():从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。此时可以使用distinct(),注意只有在PostgreSQL中支持按字段去重。)

  返回特殊的对象列表:

    7.values() :返回一个列表,里面是字典,括号里可以加条件

    8.values_list() :返回一个列表,里面是元祖,括号里可以加条件

  返回具体对象的:

    9.get():获取某一条,娶不到就报错

    10.first():默认按id取第一个,娶不到就是none,不会报错。

    11.last();默认按id取最后一个,娶不到就是none,不会报错。

    返回布尔值的:

    12.exists():判断查询结果是否存在

    返回数字的:

    13.count(): 计数 。

二 模糊查询,神奇的下划线:

models.Tb1.objects.filter(id__lt=, id__gt=)   # 获取id大于1 且 小于10的值

models.Tb1.objects.filter(id__in=[, , ])   # 获取id等于11、、33的数据
models.Tb1.objects.exclude(id__in=[, , ]) # not in models.Tb1.objects.filter(name__contains="ven") # 获取name字段包含"ven"的
models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感 models.Tb1.objects.filter(id__range=[, ]) # id范围是1到3的,等价于SQL的bettwen and 类似的还有:startswith,istartswith, endswith, iendswith  date字段还可以:
models.Class.objects.filter(first_day__year=)

三 orm外键

  查询:

     一对一:(不存在正反向,直接查)

models.Author.objects.get(id=).au.tel # 通过id查电话 (基于对象的)
ss= models.Author.objects.filter(name='刘能').values('au__tel')[0]['au__tel'] # 通过名字拿电话,基于字段查

    一对多:

基于对象查:
  正向查(假设书和出版设是一对多):
  models.Book.objects.get(id=).publis.name # 通过书的id查出版社
  反向查:
  models.Publish.objects.get(name='锅盖头出版社').book__set.all() # 通过出版社拿书
基于字段查:
  正向查(正向按属性,反向按表名):
    models.Book.objects.filter(title='天龙九部').values(publis__name) # 通过书查出版设, 前面的是条件
反向查 
  models.Publish.objects.filter(name='锅盖头出版社').values(book__title) # t通过0出版社拿书

  多对多:

基于对象查:
  正向查:(书和作者)
   models.Book.objects.get(id=1).authors.all().values(name)# 通过书拿作者
  反向查:

  models.Author.objects.get(name=刘能).book_set.all().values('title') 通过作者拿书
基于字段查询(正向按属性,反向按表名):
  正向查
  models.Book.objects.filter(title='天龙九部').values(authors__name) #通过书拿作者
  反向查:
  models.Author.objects.filter(name='刘能').values(book__title) # 通过作者拿书
 

ajango--orm操作的更多相关文章

  1. Python/Django(CBV/FBV/ORM操作)

    Python/Django(CBV/FBV/ORM操作) CBV:url对应的类(模式) ##====================================CBV操作============ ...

  2. python/ORM操作详解

    一.python/ORM操作详解 ===================增==================== models.UserInfo.objects.create(title='alex ...

  3. Django中ORM操作

    ORM操作: class UserInfo(models.Model): username = models.CharField(max_length=32) password = models.Ch ...

  4. Django的ORM操作

    ORM操作 select * from tb where id > 1 # 对应关系 models.tb.objects.filter(id__gt=1) models.tb.objects.f ...

  5. python 外键用法 多对多关系 ORM操作 模板相关

    一.app/models中写类(设计表结构) 1.普通类 class  A(models.Model): id=modles.AutoField(primary_key=True) name=mode ...

  6. Django之ORM操作

    Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...

  7. Django之ORM操作(聚合 分组、F Q)

    Django之ORM操作(聚合 分组.F Q) 聚合 aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作.   键的名 ...

  8. python第一百零五天 ---Django 基础 路由系统 URL 模板语言 ORM 操作

    一 路由系统 URL 1 url(r'^index/',views.index) url(r'^home/', views.Home.as_view()) 2 url(r'^detail-(\d+). ...

  9. Django ORM 操作 必知必会13条 单表查询

    ORM 操作 必知必会13条 import os # if __name__ == '__main__': # 当前文件下执行 os.environ.setdefault('DJANGO_SETTIN ...

  10. 在pycharm中进行ORM操作

    打开manage.py, 复制 import..... if.......os.....  导入django,开启django, 导入app中的models  orm操作 import os if _ ...

随机推荐

  1. lr12介绍2

    1.HTTP组成 请求1)方法,host ,协议,协议版本 2)请求头:客户端环境 3)请求正文: 响应:1)协议类型,协议版本,状态码 2)服务器环境 3)响应正文 2.cookie是采用客户端保存 ...

  2. python之路-变量

    变量定义的规则: - 变量名只能是字母.数字.或下划线的任意组合 - 变量名的第一个字符不能是数字 - 以下关键字不能声明为变量名  ['and','as','assert','break','cla ...

  3. mybatis支持jdk8等localdate类型

    大家知道,在实体Entity里面,可以使用java.sql.Date.java.sql.Timestamp.java.util.Date来映射到数据库的date.timestamp.datetime等 ...

  4. 高通 MSM8K bootloader之一: SBL1

    MSM8K Boot Flow  转自:http://www.cnblogs.com/liang123/p/6325257.html            http://blog.csdn.net/F ...

  5. Javase系列之面向对象(一)

    作为一个Java程序员,我们每天做的事情就是OOP(面向对象),可以说万物皆对象,Java是一门面向对象的程序语言,鉴于基本的面向对象知识也是一个较为庞杂的模块,所以博主我准备用多篇文章去介绍Java ...

  6. 程序执行流程:猜数字游戏;库的使用:turtle

    >>> import turtle >>> turtle.circle(50) >>> turtle.circle(100) Python 3.6 ...

  7. js获取元素属性值为空的原因和解决办法

    问题描述:js获取某元素的属性值为空 代码: <!-- css定义在head中 --> <style> #box{ width: 100px; height: 100px; b ...

  8. 可编程逻辑控制器(PLC)漏洞挖掘思路与验证

    mailto wangkai0351@gmail.com 随时记录千奇百怪的漏洞挖掘思路,主要针对STEP7 v5+西门子S7-300/400系列PLC,欢迎同行前来交流. 组态信息下载完整性攻击 思 ...

  9. Python第五章(北理国家精品课 嵩天等)

    函数和代码复用 函数的定义和使用 def <函数名>(<参数(0个或多个)>): <函数体> return <返回值>可选参数放在不可选参数之后*b不定 ...

  10. random模块用法

    最近生病,学习进度少许拖延,, import random # 随机取0~1之间的小数 print(random.random()) # 随机取2数之间的整数 print(random.randint ...