Flask-sqlalchemy(二)

1. Python数据库框架

  • Python有大部分的数据库引擎包,包括开源的和商业的。Flask在可使用的数据库包上没有限制,所以你可以使用MySQL、Mariadb, Postgres、SQLite、Redis、MongoDB或者CouchDB中你喜欢的任何一个。

  • 数据库抽象层包: 如SQLAlchemy或MongoEngine让你像操作常规Python对象那样,而不是数据库实体表、文档或查询语句。

2. 性能比较

2-1. 性能

ORM和ODM的转化需要从对象域转化为数据库域,所以会有一些开销。大多数情况下,性能损耗是微不足道的,但总有例外。一般来说,ORM和ODM获得的生产力远远超过了性能下降的那部分,所以这不是一个有效的论点来完全抛弃ORM和ODM。应该关心的是选择怎样的数据库抽象层,提供可访问底层数据库中特定操作,就像本地数据库指令那样实现的抽象层最佳。

2-2. 可移植性

数据库的选择必须考虑开发和生产平台。例如,如果你计划在云主机上托管应用程序,那么你应该找出提供该服务的数据库。
另一方面ORM和ODM的可移植性不错。尽管一些框架只为单个数据库引擎提供抽象层,有些抽象层更高级,可以选择哪种数据库引擎且访问使用的是同一个面向对象的接口。最好的例子就是SQLAlchemy ORM,支持一组关系数据库引擎,包括流行的MySQL、Postgres和SQLite。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值