Web.py中Sqlalchemy scoped_session的使用

发布时间:2020-06-24 发布网站:脚本之家
价值2580元廖雪峰前端视频终终终于免费啦!
脚本之家收集整理的这篇文章主要介绍了Web.py中Sqlalchemy scoped_session的使用脚本之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
Sqlalchemy中,创建Session是一件比较耗资源的事情.
在Web环境中,我们需要以一种节省的方式使用,SA提供了一个对Session的包装,scoped_session,以确保能共享一个Session.
官方文档的描述 http://www.sqlalchemy.org/docs/05/session.html#unitofwork_contextual_creating
文档中并没有直接给出最佳实践.

我做了一点的google search后,将代码改为:
#sqlalchemy
engine = create_engine('mysql://root:passwd@localhost/dbname',echo=True,pool_recycle = 60)

#loading
def loadsa():
    session = scoped_session(sessionmaker(autoflush=True,bind=engine))
    web.ctx.sadbsession = session
    web.ctx.db = session()
    
#unloading
def unloadsa():
    web.ctx.db.close()
    web.ctx.sadbsession.remove()

#processor
app.add_processor(web.loadhook(loadsa))
app.add_processor(web.unloadhook(unloadsa))

在web程序里,可以:
db = web.ctx.db
db.query(user).....

总结

以上是脚本之家为你收集整理的Web.py中Sqlalchemy scoped_session的使用全部内容,希望文章能够帮你解决Web.py中Sqlalchemy scoped_session的使用所遇到的程序开发问题。

如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢交流学习经验,点击链接加入脚本之家官方QQ群:1065694478