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版本的方法即可。

相关推荐
知识分享小能手1 小时前
数据预处理入门学习教程,从入门到精通, 实战演练——数据分析师岗位分析知识点详解(8)
python·学习·信息可视化
Wonderful U1 小时前
Python+Django实战:打造智能生鲜果蔬进销存管理系统(采购入库、库存预警、销售开单、毛利统计)
数据库·python·django
.千余1 小时前
【C++】深挖STL list底层:解迭代器与节点存储逻辑
开发语言·c++·笔记·学习·其他
yuhuofei20211 小时前
【Python入门】Python中的集合set
python
淡水瑜1 小时前
C# 实操
开发语言·c#
雪落漂泊1 小时前
C++ 继承与多态(上)
开发语言·c++
skywalk81631 小时前
我想基于kotti-py312 ,制作一个多中文编程语言的宣传网站,主要包括文档、playground 示例和学习 (Codearts制作)
开发语言·学习·编程
聆风吟º1 小时前
【C++11新章】列表初始化详解
开发语言·c++·列表初始化
大雨淅淅1 小时前
【机器人】ROS2 机械臂控制(MoveIt2)从入门到实战
人工智能·python·神经网络·学习·算法·机器学习·机器人