一、ORM回顾

    

1. 内容回顾
1. Django中使用ORM连接MySQL的步骤:
1. 创建数据库
2. 告诉Django连接哪个数据库
在settings.py中设置数据库相关的链接信息
3. 告诉Django使用pymysql代替MySQLdb来连接数据库
在和setting.py同级的__init__.py中写上
import pynmysql
pymysql.install_as_MySQLdb()
4. 在models.py中定义类
5. 执行两个命令
1. python manage.py makemigrations --> 将model.py中的变更记录 登记在小本本上,对应的是app/migrations/xxx.py
2. python manage.py migrate --> 将上一步得到的变更记录翻译成SQL语句去数据库执行 2. ORM一对一(OneToOneField):
1. 完全可以存在一张表里 2. 为什么要拆分呢?
当一张表里字段比较多,
并且当某一部分字段的查询需求比另外一些要高很多的时候 3. ORM查询练习:
详见今日代码:周末ORM作业.py 4. ORM 单表操作:
1. create
2. get
3. delete
4. 修改
1. update() --> 只更新指定字段
2. obj.属性 = 值 --> 所有字段都更新
obj.save()
5. ORM外键操作
1. 外键应该设置在哪一张表里 --> 通常放在多的那一边
2. 正向查 .属性
3. 反向查 表名_set.all()
6. 多对多字段
1. 多对多字段应该设置在哪一张表?
2. 多对多的方法
1. add
2. set
3. clear
4. remove
7. ORM进阶
1. 聚合和分组
aggregate
annotate
2. F和Q
1. F:字段与字段之间作比较的时候用F/使用原来字段的值做更新的时候
2. Q: 对查询做并集操作时
3. 事务

  

 import os

 if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "orm_demo.settings") import django django.setup() # ORM查询练习
from app01 import models # 查询书名里老男孩的书
# ret = models.Book.objects.filter(title__contains='老男孩')
# print(ret) # 查找出版日期是2017年的书
# ret = models.Book.objects.filter(publish_date__year=2017)
# print(ret) # 查找出版日期是2017年的书名
# ret = models.Book.objects.filter(publish_date__year=2017).values("title")
# print(ret) # 查找价格大于10元的书
# ret = models.Book.objects.filter(price__gt=10)
# print(ret) # 查找价格大于10元的书名和价格
# ret = models.Book.objects.filter(price__gt=10).values_list("title", "price")
# print(ret) # 查找memo字段是空的书
# ret = models.Book.objects.filter(memo__isnull=True)
# print(ret) # 查找名字以沙河开头的出版社
# ret = models.Publisher.objects.filter(name__startswith="沙河")
# print(ret) # 跨表查询
# 查找书名是“跟Alex送外卖”的书的出版社
# 1. 基于对象的查询
# book_obj = models.Book.objects.filter(title='跟Alex送外卖').first()
# book_obj.publisher # 和我这本书关联的出版社对象
# ret = book_obj.publisher.name
# print(ret)
# 2. 基于字段的查询
# ret = models.Publisher.objects.filter(book__title='跟Alex送外卖')
# print(ret) # 查找书名是“跟老男孩学Linux”的书的所有作者
# 1. 基于对象的查询
# book_obj = models.Book.objects.filter(title='跟老男孩学Linux').first()
# ret = book_obj.author.all() # 反向查询是表名_set
# print(ret)
# 2. 基于字段的查询
# ret = models.Author.objects.filter(book__title='跟老男孩学Linux')
# print(ret) # 查找书名是“跟老男孩学Linux”的书的作者的邮箱
# 1. 基于对象的查询
# book_obj = models.Book.objects.filter(title='跟老男孩学Linux').first()
# author_objs = book_obj.author.all()
# for author in author_objs:
# print(author.detail.email)
# 2. 基于字段的查询
# ret = models.Author.objects.filter(book__title='跟老男孩学Linux').values("detail__email")
# print(ret) # update和直接属性修改的区别
# 1. update
# models.Book.objects.filter(id=1).update(price=999.99) # 2. obj.price = 99.99
# book_obj = models.Book.objects.filter(id=1).first()
# book_obj.price = 99.99
# book_obj.save() # 求所有书的平均价格
from django.db.models import Avg
# ret = models.Book.objects.all().aggregate(xx=Avg("price"))
# print(ret) # 求每个作者出版的书的平均价格
# ret = models.Author.objects.annotate(xx=Avg("book__price")).values("name", "xx")
# print(ret) # 查询出版日期是2017年或者价格小于100块的书
# from django.db.models import Q
# # ret = models.Book.objects.filter(publish_date__year=2017, price__lt=100)
# ret = models.Book.objects.filter(Q(publish_date__year=2017) | Q(price__lt=100))
# print(ret) # 事务
# from django.db import transaction
#
# try:
# with transaction.atomic():
# # 先创建一个出版社
# publish_obj = models.Publisher.objects.create(name='腹疼出版社', city="沙河")
# # 把新创建的出版社和第一本书关联
# models.Book.objects.get(id=100).publisher = publish_obj
# except Exception as e:
# print(str(e)) # 不使用事务方式
try:
# 先创建一个出版社
publish_obj = models.Publisher.objects.create(name='腹疼出版社', city="沙河")
# 把新创建的出版社和第一本书关联
models.Book.objects.get(id=100).publisher = publish_obj
except Exception as e:
print(str(e))

常用ORM查询练习

from functools import wraps

def wrapper(func):
@wraps(func) # 伏笔:Flask中会用到这个!!!
def inner(*args, **kwargs):
print("装饰器工作中...")
func(*args, **kwargs)
return inner @wrapper
def f1(arg):
"""
这是一个测试装饰器修复技术的函数
:param arg: 随便传
:return: 没有
"""
print(arg) f1('呵呵')
print(f1.__doc__)

装饰器修复技术

二、cookie session

0. 登录的例子
无法判断用户是否登陆!! 1. Cookie
1. Cookie是什么?
就是保存在浏览器上的特殊的键值对
2. Cookie的特点
1. 服务端返回响应的时候 告诉浏览器要保存的键值对,浏览器可以设置不让服务端记录cookie
2. 浏览器每次访问同一个网站的时候会携带着当前这个网站保存在浏览器端的键值对 3. Cookie能做什么?
1. 做登录 *****
2. 记录用户的浏览习惯
3. 简单的访问限制
4. Cookie其它配置项
1. 超时时间: max_age = 5 单位是秒;不设置超时时间的话默认是关闭浏览器就失效
2. 加密的Cookie
5. 需要掌握的是:
django操作Cookie的方法
            1)获取cookie
              request.COOKIES['key']
              request.get_signed_cookie(key,default=RAISE_ERROR,salt='',max_age=None)
              
            2)设置cookie
              rep = HttpResponse(...)
        
 rep = render(request, ...)
              rep.set_cookie(key,value,....)
              rep.set_signed_cookie(key,value,salt='加密盐',。。。。。。)
---------------------------------------------------------------------------------------------              

参数:

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获取(不是绝对,底层抓包可以获取到也可以被覆盖)

----------------------------------------------------------------------------------------
              
            3)删除cookie
              rep.delete_cookie("user") # 删除用户浏览器上之前设置的usercookie 2. Session
1. 接收请求返回响应
2. 返回响应时,生成一个特殊的字符串
3. 在后端开一块空间保存你这个请求的相关数据
4. 返回响应 下一次请求:
1. 你带着 我之前给你的字符串
2. 拿着你的字符串去找你对应的箱子
3. 在箱子中根据key取值           

  

session方法:

  

# 获取、设置、删除Session中数据
request.session['k1']
request.session.get('k1',None)
request.session['k1'] = 123
request.session.setdefault('k1',123) # 存在则不设置
del request.session['k1'] # 所有 键、值、键值对
request.session.keys()
request.session.values()
request.session.items()
request.session.iterkeys()
request.session.itervalues()
request.session.iteritems() # 会话session的key
request.session.session_key # 将所有Session失效日期小于当前日期的数据删除
request.session.clear_expired() # 检查会话session的key在数据库中是否存在
request.session.exists("session_key") # 删除当前会话的所有Session数据
request.session.delete()
  
# 删除当前的会话数据并删除会话的Cookie。
request.session.flush()
这用于确保前面的会话数据不可以再次被用户的浏览器访问
例如,django.contrib.auth.logout() 函数中就会调用它。 # 设置会话Session和Cookie的超时时间
request.session.set_expiry(value)
* 如果value是个整数,session会在些秒数后失效。
* 如果value是个datatime或timedelta,session就会在这个时间后失效。
* 如果value是0,用户关闭浏览器session就会失效。
* 如果value是None,session会依赖全局session失效策略。

三、预习和扩展

  1.回顾

  from django.utils.decorators import method_decorator  # 不会将get post等对象方法的self传入装饰器的*args等中
  @wraper修饰的区别 直接装饰的会

python全栈开发day69-cookie、session的更多相关文章

  1. python全栈开发目录

    python全栈开发目录 Linux系列 python基础 前端~HTML~CSS~JavaScript~JQuery~Vue web框架们~Django~Flask~Tornado 数据库们~MyS ...

  2. Python全栈开发【面向对象进阶】

    Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...

  3. Python全栈开发【面向对象】

    Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...

  4. Python全栈开发【模块】

    Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...

  5. Python全栈开发【基础四】

    Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...

  6. Python全栈开发【基础三】

    Python全栈开发[基础三]  本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...

  7. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

  8. Python全栈开发【基础一】

    Python全栈开发[第一篇] 本节内容: Python 的种类 Python 的环境 Python 入门(解释器.编码.变量.input输入.if流程控制与缩进.while循环) if流程控制与wh ...

  9. python 全栈开发之路 day1

    python 全栈开发之路 day1   本节内容 计算机发展介绍 计算机硬件组成 计算机基本原理 计算机 计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可 ...

随机推荐

  1. bzoj 1175: The stairways of Saharna

    一道杨氏矩阵的题,萌新初入门,还不是很懂,这篇 blog 讲的超级好(就是看图有点麻烦) 据说这玩意儿可以代替堆和平衡树用,支持插入.删除.查询,跑得还挺快的(慢着,复杂度好像是 n^2 ? 而且空间 ...

  2. C# AutoResetEvent 使用整理

    AutoResetEvent 允许线程通过发信号互相通信.通常,此通信涉及线程需要独占访问的资源. 线程通过调用 AutoResetEvent 上的 WaitOne 来等待信号.如果 AutoRese ...

  3. MD5加密算法工具类

    import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorith ...

  4. HBase基础架构及原理

    1. HBase框架简单介绍 HBase是一个分布式的.面向列的开源数据库,它不同于一般的关系数据库,是一个适合于非结构化数据存储的数据库.另一个不同的是HBase基于列的而不是基于行的模式.HBas ...

  5. django的内置信号

    Model singnalspre_init 在model执行构造方法之前自动触发post_init django的model在执行构造方法之后,自动触发pre_save django的对象保存之前, ...

  6. Oracle 闪回

    Oracle 闪回特性(FLASHBACK DATABASE) 本文来源于:gerainly 的<Oracle 闪回特性(FLASHBACK DATABASE) > -========== ...

  7. Confluence 6 PostgreSQL 问题解决

    如果 Confluence 提示没有 class 文件,你可能将你的 JDBC 驱动放置到了错误的文件夹. 如果你不能从你从 Confluence 中连接到 PostgreSQL ,并且这 2 个服务 ...

  8. Confluence 6 使用 Decorator 宏

    Decorator 宏(Macros)是 Velocity  宏.这个宏可以被用来在页面编辑 Custom decorators 中创建复杂或者可变的部分,例如菜单,页面其他部分等.Decorator ...

  9. ios 输入框问题

    去除ios输入框阴影 input,textarea{-webkit-appearance:none; outline: none; } ios有边框时设置boder-radius:0: 去除默认圆角问 ...

  10. Java测试的题目感想

    日期:2018.9.24 星期一 博客期:012 说起来测试真的是来的时候信心满满,考完的时候慌得出神!我感觉自己会用Scanner类做输出和文件操作就可以在有限时间内把它搞出来了!事实证明我错了!我 ...