python flask中使用or查询和and查询,还有同时使用or、and的情况

ops/2025/1/24 7:45:22/

在 Flask 中处理数据库查询时,通常会结合使用 ORM 工具,例如 SQLAlchemy。以下是 or 查询、and 查询以及两者同时使用的示例。

文章目录

  • 基础准备
  • 1. 使用 or_ 查询
  • 2. 使用 and_ 查询
  • 3. 同时使用 or_ 和 and_
  • 4. 更加复杂的嵌套查询

基础准备

假设有一个模型 User,定义如下:

python">from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import or_, and_db = SQLAlchemy()class User(db.Model):id = db.Column(db.Integer, primary_key=True)name = db.Column(db.String(50))email = db.Column(db.String(100))age = db.Column(db.Integer)

1. 使用 or_ 查询

or_ 用于构造多个条件之间的“或”关系。例如,查询名字为 “Alice” 或者年龄大于 25 的用户:

python">from sqlalchemy import or_users = User.query.filter(or_(User.name == 'Alice', User.age > 25)).all()

2. 使用 and_ 查询

and_ 用于构造多个条件之间的“与”关系。例如,查询名字为 “Alice” 且年龄大于 25 的用户:

python">from sqlalchemy import and_users = User.query.filter(and_(User.name == 'Alice', User.age > 25)).all()

注意:在 SQLAlchemy 中,如果是简单的“与”关系,直接用逗号分隔条件即可,不需要显式使用 and_:

python">users = User.query.filter(User.name == 'Alice', User.age > 25).all()

3. 同时使用 or_ 和 and_

假设查询的条件是:
● 名字为 “Alice” 或年龄大于 25,
● 并且邮箱以 “@example.com” 结尾。
可以这样组合:

python">from sqlalchemy import or_, and_users = User.query.filter(and_(or_(User.name == 'Alice', User.age > 25),User.email.like('%@example.com'))
).all()

4. 更加复杂的嵌套查询

例如,查询名字为 “Alice” 并且(年龄大于 25 或邮箱以 “@example.com” 结尾)的用户:

python">users = User.query.filter(User.name == 'Alice',or_(User.age > 25,User.email.like('%@example.com'))
).all()

http://www.ppmy.cn/ops/152686.html

相关文章

【GPON实战】7360局端和C300局端流量统计指令

引言 在研发和生产ONT的过程,LAN口 和PON口打流是必测项。当发生打流丢包时需要排查是ONT引起的丢包还是局端环境导致的丢包的问题。本文介绍Nokia 7360局端和中兴C300局端,查询ONT接口流量统计、PON口流量统计和上联口流量统计,快速排查丢包…

osg3.6.5 osgEarth3.2中,鼠标操作地球放大、缩小、旋转发生屏闪

osg系列文章目录 文章目录 osg系列文章目录前言一、分析原因二、最终解决方法三、完整代码 前言 osg3.6.5 osgEarth3.2中,鼠标操作地球放大、缩小、旋转发生屏闪,如下图所示,感觉晃眼睛,这谁能忍? 一、分析原因 1.…

lwIP——3 内存管理

目录 1.什么是内存管理 2.lwIP内存堆 3.lwIP内存堆程序代码解析 3.1 mem_init程序解析 3.2 mem_malloc程序解析 3.3 mem_free程序解析 4.lwIP内存池 5.lwIP内存池程序代码解析 5.1 实现lwIP内存池的文件 5.1.1 memp_priv.h 5.1.2 memp_std.h 5.1.3 memp.h memp_t 枚…

Flink Gauss CDC:深度剖析存量与增量同步的创新设计

目录 设计思路 1.为什么不直接用FlinkCDC要重写Flink Gauss CDC 2.存量同步的逻辑是什么 2.1、单主键的切片策略是什么 2.2、​​​​​复合主键作切片,怎么保证扫描到所有的数据 3、增量同步的逻辑是什么 4、存量同步结束之后如何无缝衔接增量同步 5、下游数据如何落…

B树系列详解

B树 前言1. B树的概念2. B-树的插入3. B-树的插入实现3.1 B-树节点设计3.2 插入key的过程3.3 B树的简单验证3.4 B树性能分析 4. B树和B*树4.1 B树5.2 B*树5.3 总结 前言 常见的搜索结构: 种类数据格式时间复杂度顺序查找无要求O(N)二分查找有序O( l o g 2 N log_2…

单片机-STM32 WIFI模块--ESP8266 (十二)

1.WIFI模块--ESP8266 名字由来: Wi-Fi这个术语被人们普遍误以为是指无线保真(Wireless Fidelity),并且即便是Wi-Fi联盟本身也经常在新闻稿和文件中使用“Wireless Fidelity”这个词,Wi-Fi还出现在ITAA的一个论文中。…

Cursor的详细使用指南

以下是一份关于 Cursor 的详细使用指南: 一、安装与设置 下载与安装: 首先,访问 Cursor 的官方网站,根据你的操作系统(Windows、Mac 或 Linux)下载相应的安装程序。运行安装程序,按照屏幕上的提…

GESP202309 三级【进制判断】题解(AC)

》》》点我查看「视频」详解》》》 [GESP202309 三级] 进制判断 题目描述 N N N 进制数指的是逢 N N N 进一的计数制。例如,人们日常生活中大多使用十进制计数,而计算机底层则一般使用二进制。除此之外,八进制和十六进制在一些场合也是常用…