很好奇 sqlalchemy 的 where(User.name == "spongebob") 是怎么实现传入的是表达式,而不是计算后的布尔值

2023-04-13 02:30:10 +08:00
 think2011

from sqlalchemy import select
stmt = select(User).where(User.name == "spongebob")

例如以上代码中 User.name == "spongebob" 会被解释成表达式参数,而不是我理解的变成一个布尔值(True or False)参数

是怎么做到的,这是 python 本身支持的语法吗? 总觉得很误导,像是 bug 一样

900 次点击
所在节点    Python
6 条回复
think2011
2023-04-13 15:20:59 +08:00
没有人知道吗?😥
beeeeeeat
2023-04-13 20:13:45 +08:00
Field.__eq__
Alias4ck
2023-04-14 11:29:43 +08:00
chaoshui
2023-04-14 11:34:01 +08:00
大概率是运算符重载
Pzqqt
2023-04-14 12:47:54 +08:00
think2011
2023-04-15 02:30:01 +08:00
原来如此 谢谢各位大佬!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/932104

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX