当前位置: 首页 > news >正文

F对象和Q对象

F对象和Q对象

F对象

一个F对象代表数据库中某条记录的字段的信息
作用:
通常是对数据库中的字段值在不获取的情况下进行操作

用于类属性(字段)之间的比较
语法

from django.db.models import F
F('列名')

解决一种极端事件的产生,比如用户对一条微博的点赞,假如他们同时同时点赞,点赞数的可能只增加一个,但是用F对象就会使用MySQL中的一种锁使更新语句一次只能一个用户运行

old - >update topic set like = 1 where id = xxxx
F - > update topic set like = like + 1 where id = xxxx

Q对象

当在获取查询结果集 使用复杂的逻辑或、逻辑非~等操作时可以借助于 Q对象进行操作
如: 想找出定价低于20元 或 清华大学出版社的全部书,可以写成

Book.objects.filter(Q(price__lt=20) | Q(pub="清华大学出版社"))

Q对象在 数据包 django.db.models 中。需要先导入再使用

作用:在条件中用来实现除 and(&)以外的 or()或 not(~)操作
运算符:
& 与操作
| 或操作

~ 非操作

语法:

from django.db.models import Q
Q(条件1)|Q(条件2) # 条件1成立或条件2成立
Q(条件1)&Q(条件2) # 条件1和条件2同时成立
Q(条件1)&~Q(条件2) # 条件1成立且条件2不成立
http://www.lryc.cn/news/174444.html

相关文章:

  • Visio——绘制倾斜线段
  • Linux复习-安装与熟悉环境(一)
  • Go基础语法:map
  • 开发板TFTP调试
  • MySQL---优化日志
  • 【送面试题】深入解析Cookie和Session的请求区别及使用场景
  • 010_第一代软件开发(二)
  • 基于若依ruoyi-nbcio增加flowable流程待办消息的提醒,并提供右上角的红字数字提醒(四)
  • RestTemplate:简化HTTP请求的强大工具
  • 【数据结构】什么是数据结构?
  • c++源码编译过程(翻译阶段)的若干细节概要
  • Go内置函数make和new的区别?
  • 动手学深度学习(pytorch版)第二章-2.3线性代数Note-linear-algebra
  • Docker CMD指令如何覆写
  • 动手吧,vue单独使用的复选框
  • 升级iOS17后可以降级吗?iOS17退回iOS16方法教程分享
  • 基于STM32和LORA组网的养老院智能控制系统设计(第十八届研电赛)
  • 关于Qt适配不同分辨率和缩放率时可能遇到的问题和解决方案
  • 第1篇 目标检测概述 —(1)目标检测基础知识
  • Discuz论坛网站标题栏Powered by Discuz!版权信息如何去除或是修改?
  • springboot整合aop,实现日志操作
  • openjdk和oracle jdk的区别
  • 深度学习-Python调用ONNX模型
  • [2023.09.24]: 今天差点又交白卷
  • css,环形
  • php食堂点餐系统hsg5815ABA2程序-计算机毕业设计源码+数据库+lw文档+系统+部署
  • Vite打包时使用plugin解决浏览器兼容问题
  • java Excel 自用开发模板
  • 34.CSS魔线图标的悬停效果
  • Django — 会话