- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我正在使用 MySQLdb 模块从 python 使用 MySQL 5.0。
考虑一个简单的函数来加载和返回整个数据库表的内容:
def load_items(connection):
cursor = connection.cursor()
cursor.execute("SELECT * FROM MyTable")
return cursor.fetchall()
这个查询旨在成为一个简单的数据加载,除了单个 SELECT
语句之外没有任何事务行为。
运行此查询后,可能需要一段时间才能再次使用同一连接来执行其他任务,尽管其他连接在此期间仍可以在数据库上运行。
我是否应该在 cursor.execute(...)
调用之后立即调用 connection.commit()
以确保操作没有留下未完成的事务在连接上?
最佳答案
您需要考虑两件事:
MySQL 中的默认隔离级别是REPEATABLE READ
,这意味着如果您在一个事务中运行两次SELECT
,您将看到完全相同的数据,即使其他事务已经 promise 的变化。
大多数时候,人们希望在运行第二个 select 语句时看到已提交的更改 - 这是 READ COMMITTED
隔离级别的行为。
如果您没有更改 MySQL 中的默认级别,并且您确实希望在同一个事务中运行 SELECT 两次时看到数据库中的更改 - 那么您不能在“相同”事务,您需要提交第一个 SELECT
语句。
如果您确实想要在您的事务中看到一致的数据状态,那么显然您应该不提交。
then after several minutes, the first process carries out an operation which is transactional and attempts to commit. Would this commit fail?
这完全取决于您对“是事务性的”的定义。您在关系数据库中所做的任何事情都是“事务性的”(实际上对于 MySQL 而言并非完全如此,但为了论证,如果您仅使用 InnoDB 作为存储引擎,则可以假设这一点)。
如果“第一个进程”仅选择 数据(即“只读事务”),那么提交当然会起作用。如果它试图修改另一个事务已经提交的数据,而您正在使用REPEATABLE READ
运行,您可能会收到一个错误(在等待任何锁被释放之后)。在这种情况下,我不是 100% 了解 MySQL 的行为。
您真的应该使用您最喜欢的 SQL 客户端在两个不同的 session 中手动尝试此操作,以了解行为。也请更改您的隔离级别以查看不同级别的效果。
关于mysql - 我应该在单次选择后提交吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13287749/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!