sqlalchemy 原生sql判断条件是否为空,为空则跳过

在使用 SQLAlchemy 进行数据库操作时,有时我们希望根据某些条件来执行查询,但如果这些条件为空,我们希望跳过这些条件,即不将这些条件加入到查询语句中。这在很多情况下是有用的,特别是在构建动态查询时。下面介绍几种实现这一需求的方法。

方法 1:使用 filter()and_()

你可以使用 filter() 方法配合 sqlalchemy.sql.expression.and_() 来构建查询,并通过检查条件是否为空来决定是否将它们加入到查询中。

复制代码
from sqlalchemy import create_engine, Column, Integer, String, func, and_ 
from sqlalchemy.ext.declarative import declarative_base 
from sqlalchemy.orm import sessionmaker 

Base = declarative_base() 

class MyModel(Base): 
    __tablename__ = 'my_table'
    id = Column(Integer, primary_key=True) 
    name = Column(String) 
    age = Column(Integer) 

# 创建引擎和会话 
engine = create_engine('sqlite:///mydatabase.db') 
Session = sessionmaker(bind=engine) 
session = Session() 

# 假设我们有一些可能为空的查询条件 
name_filter = 'Alice' # 可能为空或非空 
age_filter = None # 可能为空或非空 

# 构建查询 
conditions = [] 
if name_filter: 
    conditions.append(MyModel.name == name_filter) 
if age_filter is not None: 
    conditions.append(MyModel.age == age_filter) 

query = session.query(MyModel).filter(*conditions) 
results = query.all() 
print(results)

方法 2:使用 filter() 和条件表达式(三元运算符)

你也可以在 filter() 中直接使用三元运算符来决定是否添加条件。

复制代码
query = session.query(MyModel).filter(
    (MyModel.name == name_filter) if name_filter else func.True(), # 如果 name_filter 非空,则添加条件,否则始终为真(相当于不添加此条件) 
    (MyModel.age == age_filter) if age_filter is not None else func.True() # 同理,如果 age_filter 非空则添加条件,否则始终为真 
) 
results = query.all() 
print(results)

方法 3:使用 filter()None 检查(更简洁)

如果你使用的是 SQLAlchemy 1.4 或更新版本,可以利用更简洁的语法直接在 filter() 中检查 None

复制代码
query = session.query(MyModel).filter( 
    MyModel.name == name_filter if name_filter is not None else None, # 如果 name_filter 非空,则添加条件,否则不添加任何条件(相当于跳过) 
    MyModel.age == age_filter if age_filter is not None else None # 同理,如果 age_filter 非空则添加条件,否则不添加任何条件(相当于跳过) 
) 
results = query.all() 
print(results)

以上方法都可以实现根据条件是否为空来决定是否将它们加入到查询中的需求。选择适合你代码风格和SQLAlchemy版本的方法即可。

相关推荐
金銀銅鐵2 小时前
n^5 和 n 的个位数是否总相等?
python·数学
aqi005 小时前
15天学会AI应用开发(九)利用Chroma持久化向量数据
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵5 小时前
借助 Pygame 探索最大公约数的规律
python·数学·游戏
ServBay1 天前
9 个 Python 第三方库推荐,不用 AI 都好像多出一个团队
后端·python
用户8356290780511 天前
如何使用 Python 添加和管理 Excel 批注(完整示例)
后端·python
用户8356290780511 天前
使用 Python 管理 Excel 工作表:创建、复制、删除与重命名
后端·python
荣码1 天前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
用户8356290780512 天前
Python 操作 PDF 附件:添加、查看与管理指南
后端·python
宇宙之一粟2 天前
乐企版式文件生成平台
java·后端·python