- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
如果我使用事务,它会锁定表并防止其他用户进行任何更改吗?
伪代码:
begin transaction
issue a select query
issue a update query
end transaction
那么,在这两个查询之间,是否可以通过另一个更新语句或从另一个页面发出的内容进行一些更改?
或者从事务开始,使用的表会被锁定吗?
事务和锁表有什么区别?事务会隐式锁定表吗?
编辑:这就是我想要做的:
{
// Check Table2 (posted messages)
// If is_approved is FALSE for a given msg_id
{
// Set is_approved to TRUE
// Update Table1 (member details) post_count_month++
// and post_count_lifetime++
}
// Else
{
// NOOP
}
}
以上更新可由多个用户同时进行。此外,单个用户(管理员)可以删除一条消息(已接受和未接受的消息)。因此,对于删除,发布该消息的用户(要删除的用户)的 countmonth 和 countlifetime 应该递增,然后消息被删除。
这是我面临的两种情况。
最佳答案
事务和表锁定是解决不同问题的不同特性。在您的情况下,您似乎只对数据库执行一个写入操作,因此使用事务不会提供任何好处,除非您希望能够撤消更新。
看看 SELECT ... FOR UPDATE声明。
更新#1:
好的,这是一些代码:
START TRANSACTION;
SELECT member_id, is_approved
FROM posted_messages
WHERE msg_id=31416
FOR UPDATE;
UPDATE member_details
SET post_count_month=post_count_month+1, post_count_lifetime=post_count_lifetime+1
WHERE member_id=123;
UPDATE posted_messages
SET is_approved=TRUE
WHERE msg_id=31416;
COMMIT;
(考虑到我已经发明了所有查询,我不确定它会有多大帮助。理解代码总是比复制和粘贴更好。)
更新#2:
我已经编辑了示例代码以围绕事务中的查询。我说过事务和表锁定是不同的特性,现在仍然如此。但是,SELECT ... FOR UPDATE
在事务内部工作。这只是一个实现细节。
Locking of rows for update using SELECT FOR UPDATE only applies when autocommit is disabled (either by beginning transaction with START TRANSACTION or by setting autocommit to 0. If autocommit is enabled, the rows matching the specification are not locked.
关于php - 对 php 中的 mysql 事务感到困惑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8118749/
我有一个程序可以打开一个窗口并快速改变背景颜色并随机弹出矩形和椭圆形。我的代码有效,但我不知道为什么,因为我没有在我的代码中调用 repaint() 函数。当我使用我个人的 update() 函数包含
var allRapidSpells = $$('input[value^=RSW]'); 谁能告诉我这是做什么的? 最佳答案 我敢猜测您正在使用 MooTools ,一个 JavaScript 框架
我有一个抽象父类,它有多个子类。我希望 child 能够拥有一个对于该 child 的每个实例都相同的变量。我不想将构造函数传递给 child 来告诉它它的名字,因为当它可以被硬编码时,这看起来很愚蠢
我刚刚在 Git 存储库上做了一些糟糕的事情,我不知道如何解决这个问题。我什至不知道我是怎么把它弄成这样的……! 在存储库(托管在 git hub 上)上,有 3 个我感兴趣的分支:master、br
我是 GIT 的新手,在理解提交日志图时遇到问题。 我感觉每条平行线都是一个分支。虽然我的源代码只有 2 个分支。我在下面提供的提交日志图中看到 3-4 条平行线(Microsoft Team Ser
我是 WPF 的新手,ScrollViewer 让我很沮丧。要么我只是没有“得到”它,要么它是一种有限的控制。 这是我的挫折: 水平滚动错误 水平滚动条仅在列表底部可见(我必须滚动到底部才能看到) 坏
那么 $('table.selectable td.capable input:text') 比 $('table.selectable td input:text') 更好吗?换句话说,指定一个类会
我刚刚完成了计算机图形学类(class),我们必须对光线追踪器进行编程。尽管所有结果都是正确的,但我对 OpenMP 的使用感到困惑(顺便说一句,这不是类(class)的一部分)。我有这个循环(C++
与 PatternSynonyms ( explicitly bidirectional form ),pattern-to-expr 方程实际上形成了一个函数,但拼写为大写(假设您最终得到正确类型的
我是 javascript/coffeescript 新手。 有人可以解释一下为什么这个 CoffeeScript/JavaScript 会毫无延迟地快速通过吗?我对第一种情况的想法是,它是对 upd
如果我调用document.getElementsByClassName('cl'),我会得到一个 HTMLCollection。它似乎包含 Element 对象而不是 HTMLElement 对象,
这是我本月的 azure payasyougo 使用费用。 我很难理解为什么我要为标准中型应用服务付费,我认为它会包含在计算时间中?我只运行一个云服务,这对于一个没有做太多事情的云服务来说似乎有点陡峭
除了the issue I am already having之外,我还在I saw a video on it之后安装了HBase(尚未安装)之前,还安装了Zookeeper。在安装它时,我遇到了许
我正在将 XSLT 与 regexp:match exslt 函数一起使用。上述函数采用 JavaScript Regex 模式。因此,我尝试匹配一组数字 1 到 3 OR 5 到 7 OR 9 到
我想知道为什么这段代码会给出消息:SyntaxError:意外的标记其他。 var compare = function(choice1,choice2){ if(choice1===choice2)
我尝试使用复选框和 JQuery 过滤日历上的事件, $(document).ready(function () { $('.scrollable-menu :checkbox').click(f
假设我们有一个用户想要一个名为:“test/lasdhjal.txt”,无论如何。现在,如果我将其放入新的文件(输入)中;对象里面,它会认为 test/是一个文件夹,而它是名称的一部分。我能做什么呢?
问题是 stash 的更改不会留在我 stash 它们的分支中。其他分支存储将被覆盖示例: 我愿意: git checkout iss4 // made some changes gi
我是一个 java 新手,并且在 StackOverflow 错误/在类之间访问文件的能力方面遇到了一个非常令人困惑的问题。我知道根本原因可能是我进行了一些递归调用,但修复它的语法却让我无法理解。我认
public X createData(int n) { int[] values = new int[n]; Random rand = new Random(); for
我是一名优秀的程序员,十分优秀!