我正在使用Sphinx RT索引和MySQL DB,我现在遇到的问题是我需要数据保持一致,并且在它们上使用常规插入不是正确的方法,因为我可能会得到错误的索引数据或错误的数据库数据。
假设您在MySQL DB中有以下表
id, text
1, test is test
在RT索引中也有同样的结果
id, text
这里可能发生的典型竞争情况是两个用户同时更新内容。
因此,如果用户A使用以下文本进行更新
feeling good
用户B使用以下文本进行更新
nice whether
可能发生的许多事情之一是
Update RT index with user A text
Update DB
主要问题
是否有SQL命令可以从表行中选择值,并在同一SQL命令中更新该值?
更详细的问题
我在一个电子商务网站上工作,在那里我使用MYSQL数据库,它有一个products表,其中有一个列表,等待它,产品。
该表中包括一个quantity字段和一个sold字段。
quantity表示该产品的总数量,而sold是该产品的当前销售/用户购买量。
因此,如果sold字段与quantity匹配,我希望更新前端quantity,以表明它缺货。
因此,当用户购买“x”数量的产品时,我知道我可以执行以下两个SQL命令来更新sold字段:
SELECT sold FROM products WHERE pr
我希望创建具有有限特权的mysql用户,仅用于mysqldump。我们可以分配给用户的最低权限是什么,这样他就可以直接转储和加载数据库,或者这需要管理员权限?
目前,我有类似的工作,但我不确定范围:
DROP user 'dumpuser'@'localhost' ;
FLUSH PRIVILEGES ;
GRANT SELECT ON mysql.proc TO 'dumpuser'@'localhost' IDENTIFIED BY 'dumppwd';
GRANT ALL ON dbname.*
我使用的是mySQL InnoDB表。用php脚本查询Mysql数据库。当用户选择特定表中的一条记录时,我想锁定此记录,并只允许其他用户读取进程。所以我试着用
SELECT * FROM parent WHERE NAME = 'Jones' LOCK IN SHARE MODE;
所以我的问题是,当用户B尝试选择相同的记录时,如何知道该记录被锁定,当用户A尝试更新记录时,如何授权该操作。
感谢你的帮助
我正在帮助一位朋友基于网络的形式,这是为了他们的业务。我正在尝试让它准备好处理多个用户。我已经对其进行了设置,以便在显示记录进行编辑之前,使用以下代码锁定该记录。
$query = "START TRANSACTION;";
mysql_query($query);
$query = "SELECT field FROM table WHERE ID = \"$value\" FOR UPDATE;";
mysql_query($query);
(好的,这大大简化了,但这是mysql的本质)
它似乎不起作用。但是,当我从命令行直接转到mysql时
我正在使用automysqlbackup脚本来转储mysql数据库,但我希望有一个只读用户来完成此操作,这样我就不会将我的根数据库密码存储在明文文件中。
我创建了一个这样的用户:
grant select, lock tables on *.* to 'username'@'localhost' identified by 'password';
当我运行mysqldump (无论是通过automysqlbackup还是直接运行)时,我会收到以下警告:
mysqldump: Got error: 1044: Access denied for u