首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >sqlalchemy身份映射问题

sqlalchemy身份映射问题
EN

Stack Overflow用户
提问于 2011-05-03 20:35:00
回答 2查看 2.2K关注 0票数 5

身份映射和工作模式单元是sqlalchemy比django.db更具吸引力的部分原因。然而,我不确定身份映射是如何工作的,或者当应用程序被配置为wsgi并且orm直接通过api调用而不是共享服务访问时,它是否工作。我可以想象apache会为每个请求创建一个新线程,并使用它自己的python实例。因此,每个实例都有自己的sqlalchemy类实例,并且不能使用身份映射。这是正确的吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-05-03 20:57:57

我想你误解了身份映射模式。

来自:http://martinfowler.com/eaaCatalog/identityMap.html

身份映射保留了在单个业务事务中从数据库读取的所有对象的记录。

记录保存在单个业务事务的身份映射中。这意味着无论您的web服务器是如何配置的,您可能不会将它们保存的时间长于一个请求(或将它们存储在会话中)。

通常,您不会有许多用户参与单个业务事务。无论如何,您可能不希望您的用户共享对象,因为他们最终可能会做一些相互矛盾的事情。

票数 7
EN

Stack Overflow用户

发布于 2011-05-03 20:42:08

因此,这完全取决于您如何设置sqlalchemy连接。通常,您要做的是管理每个wsgi请求,使其拥有自己的线程本地会话。这个会话将知道它的所有操作,添加/更改的项等。但是,每个线程都不知道其他线程。通过这种方式,模型和映射的加载/预配置在启动时共享,但是每个请求都可以独立于其他请求操作。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5869514

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档