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

news/2025/2/1 1:10:58/

在 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/news/1568294.html

相关文章

K8S-标签管理,探针,名称空间,rc控制器,svc服务发现

1. k8s的两类API: 响应式:可以理解为基于命令行的方式创建资源。换句话说,就是不通过配置文件创建资源 声明式:可以理解为通过资源清单的方式创建资源。换句话说,就是通过配置文件创建资源 1. 标签管理 ## 创建资源清单 kind: Po…

我的毕设之路:(2)系统类型的论文写法

一般先进行毕设的设计与实现,再在现成毕设基础上进行描述形成文档,那么论文也就成形了。 1 需求分析:毕业设计根据开题报告和要求进行需求分析和功能确定,区分贴合主题的主要功能和拓展功能能,删除偏离无关紧要的功能…

0.91英寸OLED显示屏一种具有小尺寸、高分辨率、低功耗特性的显示器件

0.91英寸OLED显示屏是一种具有小尺寸、高分辨率、低功耗特性的显示器件。以下是对0.91英寸OLED显示屏的详细介绍: 一、基本参数 尺寸:0.91英寸分辨率:通常为128x32像素,意味着显示屏上有128列和32行的像素点,总共409…

HBase基础shell命令

文章目录 前言一、基本命令1. 创建名称空间2. 删除名称空间3. 查询名称空间下的所有的表4. 列出所有表5. 查看表是否存在6. 查询表中的记录数7. 创建表8. 删除表(先禁再删)9. 新增/修改数据10. 查询一行数据11. 删除特定单元格12. 删除一整行数据 前言 …

ASP.NET Core MVC

项目结构 控制器由Controller类实现,视图一般是扩展名为cshtml的文件,而模型则是只有属性的普通C#类。控制器类的名字一般以Controller结尾,并且被放到Controllers文件夹下。控制器的名字为控制器的类名去掉Controller。视图一般被放到Views…

DataWhale组队学习 leetCode task4

1. 滑动窗口算法介绍 想象你正在用一台望远镜观察一片星空。望远镜的镜头大小是固定的,你可以通过滑动镜头来观察不同的星区。滑动窗口算法就像这台望远镜,它通过一个固定或可变大小的“窗口”来观察数组或字符串中的连续区间。 滑动操作:就像…

LeetCode-180. 连续出现的数字

题目描述 表:Logs ---------------------- | Column Name | Type | ---------------------- | id | int | | num | varchar | ---------------------- 在 SQL 中,id 是该表的主键。 id 是一个自增列。找出所有至少连续出现三次…

CUDA学习-内存访问

一 访存合并 1.1 说明 本部分内容主要参考: 搞懂 CUDA Shared Memory 上的 bank conflicts 和向量化指令(LDS.128 / float4)的访存特点 - 知乎 1.2 share memory结构 图1.1 share memory结构 放在 shared memory 中的数据是以 4 bytes(即 32 bits)作为 1 个 word,依…