Django模型层相关
时间:2019-10-24
本文章向大家介绍Django模型层相关,主要包括Django模型层相关使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
ORM 查询
查看执行查询时的sql语句
如果是queryset对象 可以直接 .query 查看
配置文件中 直接配置
LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'console': { 'level': 'DEBUG', 'class': 'logging.StreamHandler', }, }, 'loggers': { 'django.db.backends': { 'handlers': ['console'], 'propagate': True, 'level': 'DEBUG', }, }}
django测试环境的搭建
在test.py文件下:
import os
if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "one_search.settings")
import django
django.setup()
# 你就可以在下面测试django任何的py文件
#注意,如果需要导入,必须在下面导入
单表查询
必知必会十三条
# 必知必会十三条
# 1.all()
# res=models.books.objects.all()
# print(res)
# 2.filter() QuerySet
# res=models.books.objects.filter(name='b3')
# print(res)
# 3.get() 数据对象本身,如取到多个对象会报错
# res=models.books.objects.get(name='b2')
# print(res)
# 4.first() 拿第一个
# res=models.books.objects.filter(publisher=2)
# print(res.first())
# 5. last() 拿最后一个
# res = models.books.objects.filter(publisher=2)
# print(res.last())
# 6.exclude 除此之外 QuerySet
# res=models.books.objects.exclude(publisher=2)
# print(res)
# 7.values QuerySet 列表套字典
# res=models.books.objects.values('name','price')
# print(res)
# 8.values_list QuerySet 列表套元组
# res = models.books.objects.values_list('name','price','publisher_id')
# print(res)
# 9.count() 统计数据的个数
# 10.distinct() 去重
"""去重:数据必须是一模一样的情况下才能去重"""
# 11.order_by()
# res = models.Book.objects.order_by('price') # 默认是升序
# # res1 = models.Book.objects.order_by('-price') # 加负号就是降序
# print(res)
# 12.reverse() 前面必须是先结果排序才可以反转
# res = models.Book.objects.order_by('price').reverse()
# print(res)
# 13.exists() 一点卵用没有
# res = models.Book.objects.filter(pk=1).exists()
# print(res)
神奇的__查询
# 神奇的__查询
# 字段__lt >>>> 小于
# res=models.books.objects.filter(price__lt=20)
# print(res)
# 字段__gt >>>> 大于
# res=models.books.objects.filter(price__gt=20)
# print(res)
# 字段__lte >>>> 小于等于
# 字段__gte >>>> 大于等于
# 字段__in(容器) >>>> 从容器中按顺序匹配相等的值,返回QuerySet对象
# res = models.books.objects.filter(price__in=[1,123])
# print(res)
# 字段__range(start,end) >>>> 从一个范围内匹配相等的值,返回QuerySet对象
# res = models.books.objects.filter(price__range=(2,124))
# print(res)
#模糊匹配
# 包含
# res=models.books.objects.filter(name__contains='b')
# print(res)
# 开头与结尾
# res=models.books.objects.filter(name__startswith='book')
# print(res)
# res=models.books.objects.filter(name__endswith='1')
# print(res)
#日期匹配
res=models.books.objects.filter(publish_date__day='23')
print(res)
多对多字段的四个方法
add() 括号内既可以传数字也可以传数据对象并且都支持传多个
set() 括号内 既可以传数字也传对象 并且也是支持传多个的但是需要注意 括号内必须是一个可迭代对象
remove() 括号内 既可以传数字也传对象 并且也是支持传多个的
clear()括号内不需要传任何参数 直接清空当前书籍对象所有的记录
跨表查询的规律
ORM跨表查询
1.子查询
2.连表查询
正反向的概念
外键字段在谁那儿 由谁查谁就是正向
谁手里有外键字段 谁就是正向查
没有外键字段的就是反向
书籍对象 查 出版社 外键字段在书籍 正向查询
出版社 查 书籍 外键字段在书籍 反向查询
正向查询按字段
反向查询按表名小写 ...
#查询书本名为占星术杀人事件的作者名称
# 正
# res=models.books.objects.filter(name='占星术杀人事件').values('author__name')
# print(res)
# 反
res=models.author.objects.filter(books__name='占星术杀人事件').values('name')
print(res)
原文地址:https://www.cnblogs.com/Sheppard/p/11734727.html
- Kafka 快速起步
- 老司机带你用python来爬取妹子图
- 爬虫必学知识之正则表达式下篇
- 爬虫必学知识之正则表达式上篇
- python爬虫常用库之requests详解
- python爬虫常用库之urllib详解
- 如何 build 出尽可能小的 docker image?
- 一步一步教你如何用python操作mysql
- 利用Python实现卷积神经网络的可视化
- SDP(13): Scala.Future - far from completion,绝不能用来做甩手掌柜
- 干货|浅谈强化学习的方法及学习路线
- 如何实时查看Docker容器占用的CPU、内存状态?
- [安全] mysqldump 备份的后门
- Elasticsearch 快速起步
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法