- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在帮助一位 friend 使用基于网络的表单,该表单适用于他们的业务。我正在努力让它准备好处理多个用户。我已将其设置为在显示记录以供编辑之前,我使用以下代码锁定记录。
$query = "START TRANSACTION;";
mysql_query($query);
$query = "SELECT field FROM table WHERE ID = \"$value\" FOR UPDATE;";
mysql_query($query);
(好吧,这大大简化了,但这是 mysql 的本质)
它似乎不起作用。但是,当我从命令行直接进入mysql时,用同一个用户登录并执行
START TRANSACTION;
SELECT field FROM table WHERE ID = "40" FOR UPDATE;
我可以有效地阻止网络表单访问记录“40”并得到超时警告。
我试过使用 BEGIN 而不是 START TRANSACTION。我尝试先执行 SET AUTOCOMMIT=0 并在锁定后启动事务,但我似乎无法从 PHP 代码中锁定该行。因为我可以从命令行锁定行,所以我认为数据库的设置方式没有问题。我真的希望我在阅读中遗漏了一些简单的东西。
仅供引用,我正在使用 Apache 2.2.14、MySQL 5.1.41 和 PHP 5.3.1 开发 XAMPP 1.7.3 版。
提前致谢。这是我第一次发帖,但过去我从这个网站上收集了很多知识。
最佳答案
问题不在于代码的语法,而在于您尝试使用它的方式。
just before the record is displayed for editing I am locking the record with the following code
据此,我假设您选择并“锁定”该行,然后向您的用户显示该编辑页面,然后当他们提交更改时,它会保存并“解锁”表格。根本问题就在这里。页面加载完成后,PHP 退出并关闭 MySQL 连接。发生这种情况时,所有的锁都会立即释放。这就是控制台的行为似乎与您的 PHP 不同的原因。控制台中的等效项是您退出程序。
您不能长时间锁定表格行以进行编辑。这不是他们的设计。如果要锁定记录以进行编辑,则需要在另一个表中跟踪这些锁定。新建一张表“edit_locks”,存储被锁定的记录id、编辑的用户id、被锁定的时间。当你想打开一条记录进行编辑时,锁定整个edit_locks表,查询这条记录是否被其他人锁定。如果不是,则插入你的锁记录,如果是,则显示一个锁住的错误。当用户保存或取消时,从edit_locks中移除锁记录。如果你想让事情变得简单,只要在你的程序想要使用它的时候锁定这个表。这将帮助您避免竞争条件。
还有一种情况可能会导致问题。如果用户打开一条记录进行编辑,然后没有保存或取消就关闭了浏览器,编辑锁将永远停留在那里。这就是为什么我说存储它被锁定的时间。编辑器本身应该每 2 分钟左右进行一次 AJAX 调用,以说“我仍然需要锁!”。当 PHP 程序收到这个“重新锁定”请求时,它应该搜索锁,然后将时间戳更新为当前。这样,锁上的时间戳总是在 2 分钟内更新。您还需要创建另一个程序来删除旧的陈旧锁。这应该每隔几分钟在 cron 作业中运行一次。它应该搜索时间戳早于 5 分钟左右的任何锁,然后删除。如果时间戳早于该时间,那么很明显编辑器关闭了一些方式,或者时间戳将在 2 分钟内更新。
就像其他人提到的那样,您应该尝试使用 mysqli .它代表“MySQL Improved”,是旧界面的替代品。
关于php - 通过 php 锁定 mysql 行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9814191/
我对 Java 并发性比较陌生(还没有阅读 JCIP,但它在我的列表中!)并且我有一个关于锁定行为的问题。具体来说,Java 是锁定对象的引用,还是锁定对象本身? 代码示例(不是 sscce,因为我不
我的团队使用 TortoiseSVN 编写版本控制代码。有时,有人使用“获取锁定”选项。是否有可能看到解决方案中的锁? 最佳答案 http://tortoisesvn.net/docs/nightly
我在使用 SVN 时遇到了一个小问题。 当我跑 svn stat我明白了: ~ some/dir 当我跑 svn commit -m "test"我明白了:svn: working copy
我启用了 jenkins 安全性,认为它会提示我创建一个帐户。我尝试在 c:/program files/jenkins 中删除和编辑我的 config.xml 文件,但我不确定如何在没有访问权限的情
实现与 S3 结合使用的简单锁定机制的推荐方法是什么? 我想做的例子: 通过对象 ID 获取锁 从 S3 读取对象 修改数据 将对象写入 S3 释放锁 理想情况下寻找基于云的锁定机制。我可以在本地使用
找到这个here : 一般来说,在以下任何情况下,请考虑在列上创建索引: 索引列上存在引用完整性约束,或者列。索引是避免全表锁的一种方法,否则,如果您更新父表主键,则需要,合并到父表中,或从父表中删除
在我的程序中,我将把每个“ block ”数据存储在一个单独的文件中。多个线程都会读取和写入各种文件,我想避免因未正确同步而可能出现的问题。本质上,我想要一个设置,其中每个文件的行为就好像它有自己的
我想使用此script作为资源,通过使用Windows API(重置管理器)与Go for Windows中的内容相同 到目前为止,我的代码是 Rstrtmgr := syscall.NewLazyD
这里的问题是:“这些选择中的哪一个对于线程安全选择的剧院具有最佳性能?” public static List lockList = initializeLocks(); public boolean
我有一个侧面菜单,单击图标时打开,单击页面或单击菜单上的项目时关闭。我正在尝试实现锁定,因此当单击锁定图标时,即使您单击菜单项或页面,菜单也不会关闭。 我能够将图标从锁定图标更改为解锁图标,但我在停止
使用 TRueType 字体编写 SDL 程序。我调用 TTF_Init() 来初始化 TTF 并使用 TTF_OpenFont( name, size ) 打开我的字体。 我有一个例程,可以使用以下
我正在尝试调试基于运行 FreeRTOS 的 STM32F3 uC 的应用程序。我已在应用程序的线程上下文中的随机位置手动将 PSP 设置为无效值(例如 0),希望触发 memManageFault/
我有以下 C# 代码: 1. List bandEdgeList; 2. 3. bandEdgeList = CicApplication.BandEdgeCache.Where(r
我正在用骰子制作游戏。这个想法是持有/锁定骰子。我把骰子做成按钮,这样现在就可以点击它们了。示例:我抛出一个“6”和一个“1”。我点击“6”,所以现在只会抛出“1”。 我对这个有点迷失了,我需要创建
我正在使用以下代码下载约 200mb 的播客并将其写入文档目录: var podcastRequest = NSURLRequest(URL: audioUrl) NSURLConnection.se
下面的类 DoStuff 启动一个线程并同步以保护监听器对象在 null 时不被访问。 现在,当从外部访问 DoStuff 类函数 setOnProgressListener() 时,我遇到了问题,因
我正在编写一个使用巨大背景 Canvas 的网站。我试图锁定浏览器调整大小处理程序以避免滚动问题(背景越界等) 这是我第一次做一个完整的后台网站。任何有关优化的建议(png 大小 580.72 KB
我是 C# 和线程的新手,我有这个问题要解决: 我有一个处理一些数据的线程,它会不时(必要时)触发我在启动线程之前设置的事件方法 (DataProcessor)。该线程位于专有 dll 中。所以我不能
我正在使用相机,我使用的是文档中给出的完全相同的示例: http://developer.android.com/resources/samples/ApiDemos/src/com/example/
我有几个座位可供用户预订。同一时间,只有一个用户可以参与预订过程,这样同一个座位就不会被多个用户预订。在我的 Java 代码中,我使用了“synchronized”关键字来完成它。这行得通。 但是,现
我是一名优秀的程序员,十分优秀!