Python 使用原生 SQL 或者 SQLAlchemy, 查询效率上差别大吗? SQLAlchemy 的优势?

2016-06-16 09:44:14 +08:00
 jinxueliu
11658 次点击
所在节点    Python
19 条回复
est
2016-06-16 09:55:08 +08:00
就是手机贴膜和不贴膜的区别。

效率还是看你的姿势水平是否高。
jjx
2016-06-16 09:55:24 +08:00
sqlalchemy 有两个层级 orm 和 sql expression, 使用 sql expression 同原生 sql 差距不大, orm 由于需要介入 session 管理, 差距随数据量增加而增大

sqlalchemy 优势一是 orm 的优势, 这不用说, 其次是 sql expression 能让你用 python 的方式去思考, 写 sql, 从而写出易于维护的查询, 比方说原先几百行上千行的 sql , 如果用原生 sql 肯定是难以维护(基本上我们这些所谓企业软件从业者, 对这类 sql 基本都是不想再看第二遍), 但用 sql expression 方式去写, 这感觉, 你得自己去体会, sql expression 基本上能达成所有原生 sql 的所有功能(其他的 orm 一般都会有不支持某有原生 sql 语句或函数)
bobuick
2016-06-16 10:42:46 +08:00
写简单的, sqlalchemy 不一定比你手写效率好。
写大量的, 复杂的。 也不一定比你手写效率好(基于你已经非常了解各种联合查询, sql 优化)。 但是大量的情况下, sqlalchemy 至少会保证比较稳定的效率, 可能某一句有些优化空间, 需要人为跟着 debug 。
相反的,大量的情况下,人类去干, 就非常没保障了, 先不说不同的人水平不同,即时同一个人,也不稳定
seki
2016-06-16 10:47:20 +08:00
如果是根据用户输入拼接的 sql 也有可能被注入攻击
mathgl
2016-06-16 10:53:45 +08:00
@jjx sqlalchemy 和 twisted 感觉一起用有些问题。
clino
2016-06-16 10:55:18 +08:00
我记得用 sqlalchemy 不拼 sql 语句的姿势可以防 sql 注入的
lixiaohan
2016-06-16 11:02:03 +08:00
跟一楼想法差不多, 效率高低看你水平高低, 其实你打印一下 sqlalchemy , 也是执行 sql, 优势是显而易见的, 你觉得代码里面写很多 sql 好 还是 写 orm 好呢? 哪个好维护? 你愿意写哪个? 但是用 orm 的前提是你的 sql 要足够好
jjx
2016-06-16 11:55:41 +08:00
@mathgl

sqlalchemy 放入另外一个工作进程, 然后用 txzmq 之类的去请求就行

sqlalchemy +postgresql +gevent 搭配的很好
mathgl
2016-06-16 13:20:16 +08:00
@jjx 这种用法几年前就有人提过,我还以为现在有更直接的办法了。
zhuangzhuang1988
2016-06-16 13:21:08 +08:00
wmttom
2016-06-16 13:36:43 +08:00
即使拥有手写高效率 SQL 能力,也推荐用 sqlalchemy 的 core ,只用连接池和 SQL 的组装,不会损失多少性能。
并且 SQL 组装变为 Python 函数之后,可以更好的分层分装,抽象复用。
从维护的角度讲,一份代码中最好不要出现多种 DSL 。
nimdanoob
2016-06-16 15:27:19 +08:00
主要是不想写 sql ,对大部分企业应用来说,提高的效率会高于性能带来的影响
jjx
2016-06-16 15:57:51 +08:00
@mathgl

没, 所以我大部分基本都转 gevent 了 :)
jinxueliu
2016-06-16 16:47:23 +08:00
@wmttom DSL 指的是什么
king110
2016-06-16 16:55:21 +08:00
查询效率感觉差不多吧,这个得看具体的业务规模了。
mathgl
2016-06-16 17:12:19 +08:00
@jjx 有没有在 windows 下用过 gevent?
jjx
2016-06-16 17:52:24 +08:00
@mathgl

一个企业应用在 windows 下跑过 3 年, gevent+postgresql+nginx+bottle, 最多 70~80 个用户访问, 没出问题, 不过现在不自虐了, 就是没有问题, windows 运维也麻烦
mathgl
2016-06-16 18:56:01 +08:00
@jjx gevent 有个 libev 的依赖,而那个东西是不是完全支持 windows 查不到什么结果。所以我一直认为 gevent 在 win 下不是什么 production ready 的。
mathgl
2016-06-17 23:25:38 +08:00
@jjx http://edsuom.com/sAsync/sasync.html 无意中发现了这个东西,似乎可以解决共用的问题。

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

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

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

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

© 2021 V2EX