sqlalchemy 学习(二)scoped session
数据库设计的难点之一,是session生命周期的管理问题。sqlalchemy提供了一个简单的session管理机制,即scoped session。它采用的注册模式。所谓的注册模式,简单来说,是指在整个程序运行的过程当中,只存在唯一的一个session对象。
创建scoped session的方法如下
- from sqlalchemy.orm import scoped_session
- from sqlalchemy.orm import sessionmaker
- session_factory = sessionmaker(bind=some_engine)
- Session = scoped_session(session_factory)
scoped_session本质上也是一个方法,它首先通过session工厂创建session对象,然后对session对象进行相应的管理。
如果需要创建session对象,可执行下面的代码。
some_session = Session()注意,由于scoped session采用的是注册模式,因此下面代码的session1和session2是一个相同的对象引用。
- session1 = Session()
- session2 = Session()
但是下面代码中的session1和session2是不同的对象引用。因为session2创建之前,session1已经被销毁。
- session1 = Session()
- session1.remove()
- session2 = Session()
介绍到这里,我们知道scoped session本质上是一个全局变量。可是,如果直接把session定义成全局变量,在多线程的环境下,会造成线程同步的问题。为此,scoped session在默认情况下,采用的线程本地化存储方式。也就是说,每个线程的session对象是不同的。这样,不同线程对数据库的操作不会相互影响。
sqlalchemy 学习(二)scoped session的更多相关文章
- SQLAlchemy 学习笔记(二):ORM
		照例先看层次图 一.声明映射关系 使用 ORM 时,我们首先需要定义要操作的表(通过 Table),然后再定义该表对应的 Python class,并声明两者之间的映射关系(通过 Mapper). 方 ... 
- java web 学习十二(session)
		一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ... 
- sqlalchemy之create_engine和session
		sqlalchemy之create_engine和session orm 实质上,一个O/R Mapping会为你生成DAL.(即为数据访问层(Data Access Layer).其功能主要是负责数 ... 
- SpringMVC入门学习(二)
		SpringMVC入门学习(二) ssm框架 springMVC 在上一篇博客中,我简单介绍了一下SpringMVC的环境配置,和简单的使用,今天我们将进一步的学习下Springmvc的操作. mo ... 
- Laravel学习笔记之Session源码解析(中)
		说明:在上篇中学习了session的启动过程,主要分为两步,一是session的实例化,即\Illuminate\Session\Store的实例化:二是从session存储介质redis中读取id ... 
- Laravel学习笔记之Session源码解析(上)
		说明:本文主要通过学习Laravel的session源码学习Laravel是如何设计session的,将自己的学习心得分享出来,希望对别人有所帮助.Laravel在web middleware中定义了 ... 
- sqlalchemy学习
		sqlalchemy官网API参考 原文作为一个Pythoner,不会SQLAlchemy都不好意思跟同行打招呼! #作者:笑虎 #链接:https://zhuanlan.zhihu.com/p/23 ... 
- Java Web之会话管理二:Session
		一.Session 在web开发中,服务器可以为每个yoghurt浏览器创建一个会话对象(Session)对象.注意:一个浏览器独占一个Session对象.因此,在需要保存用户数据时,服务器程序可以把 ... 
- emberjs学习二(ember-data和localstorage_adapter)
		emberjs学习二(ember-data和localstorage_adapter) 准备工作 首先我们加入ember-data和ember-localstorage-adapter两个依赖项,使用 ... 
随机推荐
- H5中的语义化标签
			H5中的语义化标签也就是之前的id = “header”演变而来的 只不过之前是id 现在变成了标签而已 什么是语义化: 根据内容结构化(内容语义化) 选择合适的标签(代码语义化) 便于开发者阅读和写 ... 
- 手动漏洞挖掘-SQL注入(安全牛笔记)
			substring_index(USER(),"@",l)-- #是将查询出来的结果进行切分,以@符号的方式切分 ’ union select table_name,table_s ... 
- 王译潇20162314 实验报告三plus结对编程四则运算第一阶段
			北京电子科技学院BESTI实验报告 课程:程序设计与数据结构 班级: 1623 姓名: 王译潇 学号:20162314 指导教师:娄佳鹏老师.王志强老师 实验日期:2017年5月12号 实验密级: 非 ... 
- JQuery -- Validate, Jquery 表单校验
			1. Jquery 表单验证需要插件 jQuery validation 1.7 ---验证插件需要:jQuery 1.3.2 或 1.4.2版本 http://jquery.bassistance ... 
- oracle 结构化语言查询  DML   DDL  DCL
			--结构化查询语言 (Structured Query Language),具有定义. --查询.更新和控制等多种功能,是关系数据库的标准语言. --SQL分类: -- 数据操纵语言DML Data ... 
- Vue初步认识
			什么是Vue Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架(根据需求使用特定的功 能).与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的 ... 
- 深入浅出TensorFlow(二):TensorFlow解决MNIST问题入门
			2017年2月16日,Google正式对外发布Google TensorFlow 1.0版本,并保证本次的发布版本API接口完全满足生产环境稳定性要求.这是TensorFlow的一个重要里程碑,标志着 ... 
- php模拟发送GET和POST请求
			php分别模拟发送GET和POST请求,非常实用的额,也可作PHP CURL入门级的理解教材的,示例代码如下: <?php /* ** php分别模拟发送GET与POST请求 ** */ fun ... 
- 20165332实验一 Java开发环境的熟悉
			实验一 Java开发环境的熟悉 一.Java开发环境的熟悉-1 1.实验要求: 0 参考实验要求: 1 建立"自己学号exp1"的目录 : 2 在"自己学号exp1&qu ... 
- jfinal微信支付
			private static final String appid = PropKit.get("appid"); //应用ID private static final Stri ... 
