首页 > 代码库 > python运维开发(二十)----models操作、中间件、缓存、信号、分页
python运维开发(二十)----models操作、中间件、缓存、信号、分页
内容目录
- select Form标签数据库操作
- models操作F/Q
- models多对多表操作
- Django中间件
- 缓存
- 信号
- 分页
select Form标签补充
在上一节中我们可以知道Form标签有两个作用,一个做用户提交数据验证,一个是生成HTML标签
在生成HTML标签中可以生成select标签,select的选项数据我们可以在数据库中查询读取到。
class UserType(models.Model): caption = models.CharField(max_length=16)class UserInfo(models.Model): username = models.CharField(max_length=32) pwd = models.CharField(max_length=32) user_type = models.ForeignKey(‘UserType‘)#python3 manage.py makemigrations#python3 migrate
from app01 import modelsclass IndexForm(forms.Form): # c = [ # (1,‘CEO‘), # (2,‘COO‘) # ] c = models.UserType.objects.all().values_list(‘id‘,‘caption‘) user_type_id = forms.IntegerField(widget=forms.Select(choices=c)) def __init__(self,*args, **kwargs): # 父类构造方法:1、获取所有静态字段 2、fields = [] super(IndexForm, self).__init__(*args, **kwargs) # print(self.fields[‘user_type_id‘].widget.choices) self.fields[‘user_type_id‘].widget.choices = models.UserType.objects.all().values_list(‘id‘,‘caption‘)def index(request): # for i in range(10): # models.UserType.objects.create(caption=‘CE‘+str(i)) # c = models.UserType.objects.all().count() # print(c) form = IndexForm() return render(request, ‘index.html‘, {‘form‘: form})
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title></title></head><body> <h1>Index</h1> {{ form.user_type_id }}</body></html>
注意:普通创建完读完数据库数据之后,启动django状态,如果在向数据库中插入数据,页面不会发生变化,因为c=models.UserType.objects.all().values_list(‘id‘,‘caption‘)属于静态对象,如果要查看到更新的数据,可以重启下django就可以了,如果不想重启的话需要自定义__init__构造方法。
models F/Q操作
F:temp = salary+500models.UserInfo.objects.filter().update(salary=temp)update userinfo set salary=salary+500 from django.db.models import Fmodels.UserInfo.objects.filter().update(salary=F(‘salary‘)+500)Q:构造搜索条件1、传参models.UserInfo.objects.filter(id=123,name=‘alex‘)2、传字典d = {‘id‘: 123, ‘name‘:‘alex‘}models.UserInfo.objects.filter(**d)<input name=‘id‘ /><input name=‘name‘ />获取用户输入,并构造成字典:models.UserInfo.objects.filter(**c)3、传Q对象models.UserInfo.objects.filter(Q对象)from django.db.models import Q# q1 = Q()# q1.connector = ‘OR‘# q1.children.append((‘id‘, 1))# q1.children.append((‘id‘, 2))# q1.children.append((‘id‘, 3))# models.Tb1.objects.filter(q1)# con = Q()## q1 = Q()# q1.connector = ‘OR‘# q1.children.append((‘id‘, 1))# q1.children.append((‘id‘, 2))# q1.children.append((‘id‘, 3))## q2 = Q()# q2.connector = ‘OR‘# q2.children.append((‘status‘, ‘在线‘))## con.add(q1, ‘AND‘)# con.add(q2, ‘AND‘)## models.Tb1.objects.filter(con)
models多对多操作
- 创建 a. 方式一: class B2G(models.Model): b_id = models.ForeignKey(‘Boy‘) g_id = models.ForeignKey(‘Girl‘) class Boy(models.Model): username = models.CharField(max_length=16) class Girl(models.Model): name = models.CharField(max_length=16) b. 方式二: class Boy(models.Model): username = models.CharField(max_length=16) # girl_set class Girl(models.Model): name = models.CharField(max_length=16) b = models.ManyToManyField(‘Boy‘) - 操作: 添加: 正向 g1 = models.Girl.objects.get(id=1) g1.b.add(models.Boy.objects.get(id=1)) g1.b.add(1) bs = models.Boy.objects.all() g1.b.add(*bs) g1.b.add(*[1,2,3]) 反向 b1 = models.Boy.objects.get(id=1) b1.girl_set.add(1) b1.girl_set.add(models.Girl.objects.all()) b1.girl_set.add(*[1,2,3,4]) ... 删除: g1 = models.Girl.objects.get(id=1) g1.b.clear() # 清空和girl ID=1所关联的所有数据 g1.b.remove(2) g1.b.remove(*[1,2]) 查询: g1 = models.Girl.objects.get(id=1) # SQL g1.b.all() # SQL g1.b.filter().count() b1 = models.Boy.objects.get(id=1) b1.girl_set.all() models.Girl.objects.all().values(‘id‘,‘name‘, ‘b__username‘) models.Boy.objects.all().values(‘id‘,‘username‘, ‘girl__name‘) 更新: ORM: python操作数据库模块: MySQLdb pymysql 原生SQL # from django.db import connection # cursor = connection.cursor() # cursor.execute("""SELECT * from tb where name = %s""", [‘Lennon‘]) # row = cursor.fetchone()
Django中间件
配置文件: MIDDLEWARE_CLASSES 写类: process_request process_view process_exception process_response 1.10 配置文件: MIDDLEWARE = 原版本: 如果process_request中有return, 则所有的process_response执行一遍
缓存
信号
分页
python运维开发(二十)----models操作、中间件、缓存、信号、分页
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。