在FLASK-SQLALCHEMY 的FILTER中如何使用OR和AND来组合多种条件查询?
查找文档的时候并没有找到相关的描述,后来经过多次尝试,发现可以这样写:
首先要Import相关的库
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import or_,and_
然后定义filter:
task_filter = {
or_(
and_(
Task.task_department == current_user.user_department,
Task.task_commit_status > 0,
Task.task_complete_time >= prev,
),
and_(
Task.task_complete_time >= prev,
Task.task_members.like(‘%,‘+str(current_user.user_id)+‘,%‘),
)
)
}
上面这个filter中有两个条件组,关系为or,每个条件组里有一些and关系的条件。
filter定义完之后就可以进行查询了:
Task.query.filter(*task_filter).all()