django_day05
django_day05
内容回顾
内容回顾
对应关系
类-------表
对象-----数据行
属性------字段
django使用mysql数据库流程
创建一个mysql数据库
在settings中配置数据库
- ENGINE mysql
- NAME 数据库名称
- HOST 127.0.0.1
- PORT 3306
- USER 用户名
- PASSWORD 密码
告诉django使用pymysql模块连接mysql模块
1. 写在与项目同名的目录下的__init__.py
2. import pymysql
3. pymysql.install_as_MySQLdb()
在app下的models.py中写类
from django.db import models
class Person(models.Model):
name = models.CharField(max_length=32) #varchar(32)
执行数据库迁移的命令
python manage.py makemigrations
python manage.py migrate
常用字段
AutoField 自增字段 primary=True
CharField 字符串 max_length
BooleanField 布尔类型
IntegerField 整型 -21亿 --- +21亿 10位 不能存手机号
DateField
DateTimeField auto_now = True 新增和编辑时保存当前时间
auto_now_add = True 新增时保存当前的时间
TextField 文本类型字段的参数
null 数据库可以为空
blank 用户输入可以为空
unique 唯一约束
verbose_name 提示信息
choices 让用户选择的数据 choices=((1,'男'),(2,'女'))
default 默认值
db_column 列名
必知必会13条
返回对象列表
all 查询所有的数据
filter 查询所有满足条件的数据
exclude 查询所有不满足条件 的数据
values 查询数据的字段和值[ {} ]
values_list 查询数据的值 [()]
order_by 排序 默认升序 - 多字段排序age id
reverse 对已经排好序的queryset翻转
distinct 去重 返回对象
get 获取有且唯一的对象
first
last 返回布尔值
exists 数字
count
路由
url(r'^publisher_list/$',views.publisher_list)
url(r'^(publisher|book|author)_del/$',views.delete)
正则
\d \w + ? . *
r'^app01/publisher_list/$'
URL的命名和反向解析
静态路由
url(r'^publisher_list/$',views.publisher_list,name=pub)
模板中
'{% url 'pub' %}' --- '/publisher_list/'
py文件
from django.shotcuts import reverse
reverse('pub') --- '/publisher_list/'
分组
动态路由
url(r'^publisher_list/(\d+)/$',views.publisher_list,name=pub)
模板中
{% url 'pub' 5 %} '/publisher_list/5/'
py文件
from django.shotcuts import reverse
reverse('pub',args=(5,)) --- '/publisher_list/5/'
命名分组 可以按照命名传参
动态路由
url(r'^publisher_list/(?P<pk>\d+)/$',views.publisher_list,name=pub)
模板中
{% url 'pub' 5 %} '/publisher_list/5/'
{% url 'pub' pk=5 %} '/publisher_list/5/'
py文件
from django.shotcuts import reverse
reverse('pub',args=(5,)) --- '/publisher_list/5/'
reverse('pub',kwargs={'pk':'5'} --- '/publisher_list/6/'
外键
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "about_orm.settings")
import django
django.setup()
from app01 import models
#基于对象的查询
#正向查询
book_obj = models.Book.objects.get(pk=1)
# print(book_obj.pub) #关联的出版社对象
# print(book_obj.pub_id) #关联的出版社id
#反向查询
pub_obj = models.Publisher.objects.get(pk=1)
print(pub_obj)
# print(pub_obj.book_set,type(pub_obj.book_set)) #类名小写 set 关联所有对象
# print(pub_obj.book_set.all())
#指定related_name=‘books’
# print(pub_obj.books,type(pub_obj.books)) #类名小写 set 关联所有对象
# print(pub_obj.books.all())
#基于字段查询
ret = models.Book.objects.filter(pub__name__contains='出版社1')
# #不指定related_name='books'
# ret = models.Publisher.objects.filter(book__name='书1')
# #指定related__name='books' 不指定related_query_name='book'
# ret = models.Publisher.objects.filter(books__name='书1')
#指定related_query_name='book'
# ret = models.Publisher.objects.filter(book__name='书1')
# print(ret)
# set add create 只有对象 没有id
pub_obj.books.set(models.Book.objects.filter(id__in=[1,2]))
# remove clear 不能用
多对多
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "about_orm.settings")
import django
django.setup()
from app01 import models
author_obj = models.Author.objects.get(pk=1)
print(author_obj.books) #关系管理对象
print(author_obj.books.all()) #所关系对象集合
book_obj = models.Book.objects.get(pk=2)
# print(book_obj.author_set.all())
print(book_obj.authors.all())
# ret = models.Book.objects.filter(authors__name='李世林')
# ret = models.Author.objects.filter(books__name='书2')
#关系管理对象的方法
#all 查询所有的对象
#set 设置多对多 的关系 [id,id]
# author_obj.books.set([1,2])
#
# author_obj.books.set(models.Book.objects.filter(id__in=[3,4]))
#add 添加多对多关系
# author_obj.books.add(1,2)
# author_obj.books.add(*models.Book.objects.filter(id__in=[5,6]))#列表打散 变成对象
#remove 添加多对多的关系
# author_obj.books.remove(3,4)
# author_obj.books.remove(*models.Book.objects.filter(id__in=[5,6]))
#clear 清空多对多的关系
# author_obj.books.clear()
# create 新建一个对象和当前的对象建立关系
# author_obj.books.create(name='sdawd',pub_id='1')
ret= book_obj.authors.create(name='adadadfdcvxdc')
print(ret)
神奇的下划线
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "about_orm.settings")
import django
django.setup()
from app01 import models
ret = models.Person.objects.filter(pid__lt=5) #less than 小于
ret = models.Person.objects.filter(pid__gt=5) #greater than 大于
ret = models.Person.objects.filter(pid__lte=5) #less than equal 小于等于
ret = models.Person.objects.filter(pid__range=[1,6]) #左右都包含 范围
ret = models.Person.objects.filter(pid__in=[1,5,6]) #左右都包含 成员判断
ret = models.Person.objects.filter(name__contains='lsl') # like 模糊查询
ret = models.Person.objects.filter(name__icontains='lsl') # like 模糊查询 忽略大小写
ret = models.Person.objects.filter(name__startswith='l') # like 模糊查询 以什么开头
ret = models.Person.objects.filter(name__istartswith='l') # like 模糊查询 以什么开头 忽略大小写
# ret = models.Person.objects.filter(name__endwith='l') # like 模糊查询 以什么结尾
# ret = models.Person.objects.filter(name__iendwith='l') # like 模糊查询 以什么结尾 忽略大小写
ret = models.Person.objects.filter(birth__year='2020') # like 模糊查询 以什么结尾 忽略大小写
ret = models.Person.objects.filter(birth__month='1') # like 模糊查询 以什么结尾 忽略大小写
ret = models.Person.objects.filter(birth__day='1') # like 模糊查询 以什么结尾 忽略大小写
ret = models.Person.objects.filter(birth__contains='-02-') # like 模糊查询 以什么结尾 忽略大小写
ret = models.Person.objects.filter(name__isnull=True) #字段为空
print(ret)
聚合与分组
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "about_orm.settings")
import django
django.setup()
from app01 import models
from django.db.models import Avg, Sum, Max, Min, Count
#aggregate 终止子句
ret = models.Book.objects.all().aggregate(Avg("price"))# 返回字典 #{'price__avg': 205.483333}
ret = models.Book.objects.all().aggregate(average_price=Avg('price'))# 返回字典{'average_price': 205.483333}
ret = models.Book.objects.all().aggregate(Avg("price"), Max("price"), Min("price"))# 返回字典{'price__avg': 205.483333, 'price__max': Decimal('999.00'), 'price__min': Decimal('9.90')}
ret = models.Book.objects.aggregate(Avg("price"), Max("price"), Min("price"))# 返回字典{'price__avg': 205.483333, 'price__max': Decimal('999.00'), 'price__min': Decimal('9.90')}
ret = models.Book.objects.filter(id__gt=2).aggregate(Avg("price"), Max("price"), Min("price"))# 返回字典{'price__avg': 205.483333, 'price__max': Decimal('999.00'), 'price__min': Decimal('9.90')}
print(ret)
#分组 group_by
#统计每一本书的作者个数
#annotate注释的意思 添加额外的信息
ret= models.Book.objects.annotate(Count('authors')).values()
for i in ret:
print(i)
##统计出每个出版社买的最便宜的书的价格
ret = models.Publisher.objects.annotate(Min('book__price')).values()
#按照pub_id pub_name分组
ret = models.Book.objects.values('pub','pub__name').annotate(Min('price'))
publisher_list = models.Publisher.objects.annotate(min_price=Min("book__price"))
for i in ret:
print(i)
#统计不止一个作者的图书
ret = models.Book.objects.annotate(count=Count('authors')).filter(count__gt=1)
print(ret)
#根据一本图书作者数量的多少对查询集 QuerySet进行排序
ret = models.Book.objects.annotate(count=Count('authors')).order_by('-count')
print(ret)
#查询各个作者出的书的总价格
ret = models.Author.objects.annotate(sum=Sum('books__price')).values()
ret = models.Book.objects.values('authors','authors__name').annotate(sum=Sum('price'))
for i in ret:
print(i)
F和Q
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "about_orm.settings")
import django
django.setup()
from app01 import models
from django.db.models import Avg, Sum, Max, Min, Count,F,Q
ret = models.Book.objects.filter(sale__gt=F('repertory')) #where 'sale' > 'repertory'
ret = models.Book.objects.filter(id__lte=3).update(sale=F('sale')*2 + 12)
ret = models.Book.objects.filter(Q(id__lt=3)|Q(id__gt=5)) #或者的关系
ret = models.Book.objects.filter(Q(Q(id__lt=3)|Q(id__gt=5))&Q(name__startswith='lsl')) #与的关系
# ret = models.Book.objects.exclude(id__gte=3,id__lte=5)
"""
Q()
| 或者
& 并且
~ 非
"""
print(ret)
事务
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "about_orm.settings")
import django
django.setup()
from app01 import models
from django.db.models import Avg, Sum, Max, Min, Count,F,Q
from django.db import transaction
try:
with transaction.atomic():
#一系列的操作
models.Book.objects.all().update(repertory=F('repertory') - 10)
int('sss')
models.Book.objects.all().update(sale=F('sale') + 10)
except Exception as e:
print(e)
cookie
保存在浏览器本地上的一组组键值对
特性:
- 由服务器让浏览器进行设置的
- cookie信息保存在本地浏览器 有权不保存
- 浏览器再次访问时自动携带对应的cookie
django中操作cookie
#设置cookie
request.set_cookie(key,value) # Set-Cookie: is_login=1
response.set_signed_cookie(key, value,salt='s28')#加密cookie #获取
request.COOKIES.get(key)#请求头 Cookie : is_login = 1;
request.get_signed_cookie(key,salt='s28',default='')#加密cookie #删除cookie 设置cookie值为空 超时时间为0
response.delete_cookie(key)
参数
- key, 键
- value='', 值
- max_age=None, 超时时间
- expires=None, 超时时间(IE requires expires, so set it if hasn't been already.)
- path='/', Cookie生效的路径,/ 表示根路径,特殊的:根路径的cookie可以被任何url的页面访问
- domain=None, Cookie生效的域名
- secure=False, https传输
- httponly=False 只能http协议传输,无法被JavaScript获取(不是绝对,底层抓包可以获取到也可以被覆盖)
django_day05的更多相关文章
随机推荐
- JVM学习笔记-从底层了解程序运行(一)
1:JVM基础知识 什么是JVM 1. java虚拟机,跨语言的平台,实现java跨平台 2. 可以实现多种语言跨平台,只要该语言可以编译成.class文件 3. 解释执行.class文件 java是 ...
- 几种常见的DoS攻击
DoS为Denial of Service的简称,意思是拒绝服务.DoS攻击是一种使被攻击者无法正常提供服务的攻击.常见的攻击方式有以下几种类型: LAND Local Area Network ...
- leetcode题解#3:无重复字符的最长子串
leetcode题解:无重复字符的最长子串 题目 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: s = "abcabcbb"输出: 3 解释 ...
- sql-DDL-约束
约束 对表中的数据进行限定,保证数据的正确性.有效性和完整性. 6个约束 1. 主键约束Primary Key: 唯一,不能为null -- 主键约束.和唯一约束不能同时设置 1. 含义:非空且唯一 ...
- C#请求HTTPS地址的故障分析和TLS知识点总结
背景介绍 近期收到同事反馈,在C#程序中通过HTTPClient请求一个HTTPS的地址时,在本地开发环境和测试环境均能正常执行,而部署到生产环境后发生异常且稳定复现,异常提示为:[请求被中止: 未能 ...
- 记录自己NVIDIA GeForce MX250迷之安装cuda+pytorch成功了
电脑是ubuntu20.4 Pop!_OS 20.04 LTS MX250显卡并没有列在CUDA支持的GPU里 希望文中链接的别人的博客不会消失掉. 安装了英伟达的驱动 参考了这一篇:Ubuntu 安 ...
- 各大厂的语音识别Speech To Text API使用体验
最近发现有声读物能极大促进我的睡眠,但每个前面都有一段开场语,想把它剪掉,但是有多个开场语,所以就要用到语音识别判断一下再剪. 前两年在本地搭建过识别的环境,奈何识别准确率不行,只能找找API了,后面 ...
- 分享一个基于Abp Vnext开发的API网关项目
这个项目起源于去年公司相要尝试用微服务构建项目,在网关的技术选型中,我们原本确认了ApiSix 网关,如果需要写网关插件需要基于Lua脚本去写,我和另外一个同事当时基于这个写了一个简单的插件,但是开发 ...
- AtCoder Beginner Contest 261 F // 树状数组
题目链接:F - Sorting Color Balls (atcoder.jp) 题意: 有n个球,球有颜色和数字.对相邻的两球进行交换时,若颜色不同,需要花费1的代价.求将球排成数字不降的顺序,所 ...
- jsx/tsx使用cssModule和typescript-plugin-css-modules
目录 1,前言 2,效果图 3,如何使用 3.1,安装 3.2,配置 4,示例 5,插件错误处理 5.1,错误触发原因 5.2,解决办法 1,前言 在vite/webpack搭建的项目中,不管是vue ...