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

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

文章目录

  • 基础准备
  • [1. 使用 or_ 查询](#1. 使用 or_ 查询)
  • [2. 使用 and_ 查询](#2. 使用 and_ 查询)
  • [3. 同时使用 or_ 和 and_](#3. 同时使用 or_ 和 and_)
  • [4. 更加复杂的嵌套查询](#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()
相关推荐
zzzzzz3104 小时前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐4 小时前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
兵慌码乱16 小时前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot17 小时前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
顾林海1 天前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱1 天前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
曲幽1 天前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
荣码1 天前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱2 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵2 天前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学