- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
这是我在 php 中的代码结构:
function myfunction(){
try{
// begin Transaction
// get last row by this query:
// SELECT id FROM tableName WHERE t_date+INTERVAL 1 MINUTE< NOW() LIMIT 1
// store the returned id inside $id if exists, $id=0 otherwise (out of id for now)
// update the row to the current time to show it is fetched now by this query:
// UPDATE tableNAME SET t_date=NOW() WHERE id=$id
// end of Transaction
// commit
}catch (PDOException $e){
// failed, rollback
$id = 0;
}
return $id
}
如你所见,我的函数:
代码工作没有任何问题,我没有任何与代码结构相关的问题。
问题
如您所见,每个请求的 ID 应该始终是唯一的。我正在使用 MySQL 并且想知道:
如果两个用户(或更多)同时打开一个页面并且因为:
我是否总能得到预期的独特结果?
我读过@symcbean 关于 Does MySQL queue queries? 的回答他提到:
It's very improbable that 2 queries could arrive at the same time - but not impossible
我的代码结构是否有助于我避免并行查询?
最佳答案
考虑到两个查询同时到达的场景,事务所做的只是为每个线程的数据库操作保证 ACID 行为。这并不意味着两组选择/更新不能同时发生;这实际上可能发生。
处理此问题的一种方法是使用 SELECT ... FOR UPDATE
:
SELECT id FROM tableName WHERE t_date + INTERVAL 1 MINUTE < NOW() LIMIT 1 FOR UPDATE;
UPDATE tableNAME SET t_date=NOW() WHERE id = $id;
FOR UPDATE
子句将告诉 MySQL 锁定单个匹配的 id
行,这样即使有另一个线程进来,它也无法锁定,因此无法更新。
编辑:
正如@tadman 指出的那样,您甚至可以在这里只使用一个查询:
UPDATE tableNAME
SET t_date = NOW()
WHERE id = (SELECT id FROM tableName WHERE t_date + INTERVAL 1 MINUTE < NOW() LIMIT 1);
关于php - 我的查询是否锁定该行以供下次使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55521355/
大家好我有一个应用程序可以打开一个包含文本和图像组合的文章的 WebView 。如您所知,文章有不同的字体,我想知道是否有办法让 Web View 呈现几种 Helvetica 字体,就像在安装了这些
我正在寻找一种好的格式来归档旧 Linux 计算机的整个文件系统。 西藏自治区 tar.gz 格式非常适合归档具有 UNIX 样式属性的文件,但由于压缩应用于整个归档,因此设计排除了随机访问。相反,如
我最近一直在苦苦挣扎,因为我不得不更改我不久前编写的一些代码以在 Qt 中进行图像处理和 OpenGl以支持多线程。 问题是我想用它在一组图像上应用批量过滤器, 我正在使用 openMP 来做这样的多
我已成功将两个实际设备连接到 Azure IoTHub(在同一个 IoT 中心),并希望第二个设备接收第一个设备发送的消息。因此,在普通的 MQTT 代理中,第二个设备仅订阅该主题,但 Azure没有
我需要一些 Jenkins 作业才能通过 ssh 通过 shell 命令行访问其他一些机器。 我该怎么做? 我没有目标服务器的密码,但我有一个“ key ”文件,但是当我使用以下命令运行作业时 ssh
我在 Mac OSX Mavericks 上使用 MAMP。我想安装最新的 XDebug v2.2.4。根据 XDebug 向导,我下载了 XDebug 2.2.4 源代码。我的系统上安装了许多版本的
所以我正在制作一个程序,从用户给定的 AZ Lyrics 歌曲中提取歌词。我遇到的问题是,在将字符串转换为 URL 后,它说 Jsoup 无法解析它,因为它不接受字符串,尽管变量是我们传入的 URL。
我已经安装了 AWS .NET SDK通过 MSI 安装程序。我想使用这段代码: static IAmazonS3 client; client = new AmazonS3Client(Amazon
我正在使用 cURL 检索另一个页面,除非我有特定的 cookie,否则我看不到页面内容。 cookie 名称是 seepage,它的值必须设置为 1 才能让我看到页面内容。 我想使用 cURL 加载
目录 1、VLC代码封装 1.1 QT(C++)工程 1.2static 声明 m_instance 优化效率 1.3封装 DLL
我是 Docker 新手,但有一个 Java Web 应用程序项目,我的 Maven 构建会为其生成并安装 Docker 镜像。即 mvn clean install 产品: REPOSITORY
我正在尝试在 Debian Stretch 上做一个带有 uinput 的虚拟键盘,我可以输入字符串,比如“Toto!”,键盘会写入这个字符串。但是,我一直坚持从 C char 到键盘处理的键码的转换
我们正在 Rails 中开发一个 JSON REST API,供我们也在开发的 Android 应用程序使用。有什么方法可以保护 API,使其只能由我们特定的 Android 应用程序使用? API
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
所以我有一个问题,我有 2 个应用程序部署在具有不同端口的同一网站上,一个是登录应用程序,一个是HRIS 系统。 我的问题是,当我的登录应用程序创建 token 时并重定向到我的 hris 系统,hr
在给出的第三段代码的上下文中交谈 on this page , 有一个方法 Messenger named getBinder()返回 the IBinder Messenger 用于与 associ
我目前有一个私有(private) Java 项目,我正在尝试将其完善以供其他开发人员使用。我想做的一件事是让 Ant 自己下载 JUnit、PMD 和 FindBugs 等所需的 JAR,这样开发人
我想在 Qt 中使用 ffmpeg 库进行编程。 如何在 Windows 上将 ffmpeg 编译成 *.lib 文件? 或 如何使用Qt官方发布的编译后的*.dll文件? 还有,哪种方式比较好? 最
我正在为扩展 std::vector 实例化的 C++ 类开发 Python 绑定(bind)。为了让 Python 下标运算符为此类工作,我添加了如下所示的 __getitem__ 函数(我删除了不
我正在为 Amazon SWF 的相当简单的工作流程编写 PHP。我发现自己开始编写一个库来检查某些操作是否已经开始或完成。基本上遍历事件列表以检查事情的进展情况,然后在需要时启动适当的事件。有时这可
我是一名优秀的程序员,十分优秀!