SQLAlchemy 中 filter 和 filter_by 的区别

2025-02-25 09:07:00
admin
原创
25
摘要:问题描述:filter有人能解释一下 SQLAlchemy 中和函数之间的区别filter_by吗?我应该使用哪一个?解决方案 1:filter_by用于使用常规 kwargs 对列名进行简单查询,例如db.users.filter_by(name='Joe')可以使用 来实现相同的目的filter,不是使用...

问题描述:

filter有人能解释一下 SQLAlchemy 中和函数之间的区别filter_by吗?我应该使用哪一个?


解决方案 1:

filter_by用于使用常规 kwargs 对列名进行简单查询,例如

db.users.filter_by(name='Joe')

可以使用 来实现相同的目的filter,不是使用 kwargs,而是使用 '==' 相等运算符,该运算符已在 db.users.name 对象上重载:

db.users.filter(db.users.name=='Joe')

您还可以使用编写更强大的查询filter,例如如下表达式:

db.users.filter(or_(db.users.name=='Ryan', db.users.country=='England'))

解决方案 2:

实际上,我们最初将它们合并在一起,即有一个类似“过滤器”的方法,它接受*args**kwargs,您可以在其中传递 SQL 表达式或关键字参数(或两者)。实际上,我发现这要方便得多,但人们总是对此感到困惑,因为他们通常仍无法理解column == expression和之间的区别keyword = expression。所以我们将它们分开了。

解决方案 3:

它是一种语法糖,可以加快查询编写速度。其伪代码实现如下:

def filter_by(self, **kwargs):
    return self.filter(sql.and_(**kwargs))

对于 AND 你可以简单地写:

session.query(db.users).filter_by(name='Joe', surname='Dodson')

顺便提一句

session.query(db.users).filter(or_(db.users.name=='Ryan', db.users.country=='England'))

可以写成

session.query(db.users).filter((db.users.name=='Ryan') | (db.users.country=='England'))

您也可以通过方法直接通过 PK 获取对象get

Users.query.get(123)
# And even by a composite PK
Users.query.get(123, 321)

当使用get案例时,重要的是对象可以在没有数据库请求的情况下返回,identity map并可用作缓存(与事务相关)

解决方案 4:

filter_by使用关键字参数,而filter允许使用 Python 风格的过滤参数,例如filter(User.name=="john")

解决方案 5:

除了之前发布的所有技术信息之外, filter()filter_by()在可用性方面存在显著差异。

第二个函数filter_by()只能用于根据特定内容(字符串或某个数值)进行过滤。因此,它只能用于类别过滤,不能用于表达式过滤。

另一方面,filter()允许使用比较表达式(==、<、> 等),因此在需要“小于/大于”过滤时很有用。但也可以像filter_by()一样使用(当使用 == 时)。

只需记住这两个函数的参数类型语法不同。

相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   1492  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1344  
  IPD(Integrated Product Development)流程是一套先进的产品开发管理体系,旨在通过整合跨部门资源,实现产品的高效开发与交付。在IPD流程中,确保项目按时交付是至关重要的,它直接关系到企业的市场竞争力和客户满意度。以下将从多个关键方面探讨如何在IPD流程阶段确保项目按时交付。精准的项目规划项...
IPD流程分为几个阶段   2  
  IPD(Integrated Product Development)流程是一套先进的产品开发管理体系,旨在缩短产品上市时间、提高产品质量、降低成本并增强企业的市场竞争力。深入理解IPD流程阶段的关键要素,对于企业成功实施IPD,实现产品开发的高效运作至关重要。IPD流程的概念与重要性IPD流程强调将产品开发视为一个整...
IPD测试流程   3  
  IPD(Integrated Product Development)产品开发流程是一套先进的、旨在提高产品开发效率与质量的管理体系。在这个体系中,评审环节起着至关重要的作用,它们如同关卡,确保产品在各个阶段都朝着正确的方向前进,符合市场需求和企业战略。其中有四个评审环节尤为关键,它们分别在不同阶段对产品进行全面审视,...
研发IPD流程   5  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用