Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/302.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python SQLALchemy动态过滤器_Python_Orm_Sqlalchemy - Fatal编程技术网

Python SQLALchemy动态过滤器

Python SQLALchemy动态过滤器,python,orm,sqlalchemy,Python,Orm,Sqlalchemy,我知道您可以通过提供**kwargs来过滤\u,为SQLAlchemy的查询构建动态过滤器 比如说 filters = {'id': '123456', 'amount': '232'} db.session.query(Transaction).filter_by(**filters) 以下是我的问题: 如果我需要通过大于或小于子句进行查询,该怎么办? 例如,原始SQL: select * from transaction t where t.amount > 1

我知道您可以通过提供**kwargs来过滤\u,为SQLAlchemy的查询构建动态过滤器

比如说

    filters = {'id': '123456', 'amount': '232'}
    db.session.query(Transaction).filter_by(**filters)
以下是我的问题:

如果我需要通过大于或小于子句进行查询,该怎么办? 例如,原始SQL:

 select * from transaction t 
 where t.amount > 10 and t.amount < 100;
我建议您不要使用filter_,而是使用filter,它为您提供了更多的选择

例如,手册中的:

db.session.query(MyClass).filter(
    MyClass.name == 'some name',
    MyClass.id > 5,
)
关于你的情况:

filters = (
    Transaction.amount > 10,
    Transaction.amount < 100,
)
db.session.query(Transaction).filter(*filters)

我们是否有机会列出您提到的过滤器列表,但运算符将动态地用占位符填充,例如:op=>=value=10 filter1=f{Transaction.amount}{op}{value}filters=filter1 db.session.queryTransaction.filter*filters@Wolph字体我会很感激你的回答too@JavaSa所有操作符也可以通过Python中的模块获得。因此,您也可以使用operator.gea,b代替a>=b
def get_filter_by_args(dic_args: dict):
    filters = []
    for key, value in dic_args.items():  # type: str, any
        if key.endswith('___min'):
            key = key[:-6]
            filters.append(getattr(model_class, key) > value)
        elif key.endswith('___max'):
            key = key[:-6]
            filters.append(getattr(model_class, key) < value)
        elif key.endswith('__min'):
            key = key[:-5]
            filters.append(getattr(model_class, key) >= value)
        elif key.endswith('__max'):
            key = key[:-5]
            filters.append(getattr(model_class, key) <= value)
        else:
            filters.append(getattr(model_class, key) == value)
    return filters

dic_args = {
    'is_created': 1,
    'create_time__min': 1588125484029,
}
filters = get_filter_by_args(dic_args)
lst = session.query(model_class).filter(*filters)