首页 > 代码库 > 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
models生成表
技术分享
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})
Views 代码
技术分享
<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title></title></head><body>    <h1>Index</h1>    {{ form.user_type_id }}</body></html>
前端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操作、中间件、缓存、信号、分页