Python ORM 为什么可以不区分变量类型?

2018-07-12 20:07:50 +08:00
 miniyao

book 的 id 存在数据库里是 int,但查询的时候,给一个 int 和 string 都可以查:

book = Book.query.filter(Book.id == book_id).first()

book = Book.query.filter(Book.id == str(book_id)).first()
3948 次点击
所在节点    SQLAlchemy
4 条回复
tulongtou
2018-07-12 20:19:57 +08:00
是数据库不分 int 跟 string
miniyao
2018-07-12 20:28:15 +08:00
@tulongtou 在数据库里,还是指定了 book 的 id 类型 为 int 的呀
GTim
2018-07-12 20:43:49 +08:00
@miniyao 因为数据库会做一些转换

SELECT * FROM book WHERE id= 1 LIMIT 1;



SELECT * FROM book WHERE id= '1' LIMIT 1;

是一样的
Qzier
2018-07-13 00:47:52 +08:00
最后都会拼接成原生 sql 语句,都一样

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

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

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

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

© 2021 V2EX