我正在为一个客户端做一项工作,但由于我已经有一段时间没有使用PHP/MMySQL了,我忘记了一些简单的事情,希望你能帮我。
我有以下SQL表:
ID (non-null, autoincrement) | credit (int)
我的查询应该将整个"信用"列设置为0,除了ID较高的行。
所以我会这么做:
UPDATE $table SET credit = 0 WHERE... ?
提前感谢您的帮助:)
UPDATE $table SET credit = 0 WHERE ID > $ID
将更新和ID大于变量$ID
的任何行
如果您只想用最大ID更新行,请使用:
UPDATE $table SET credit = 0 WHERE ID = (select max(id) from $table)
编辑:正如Eggyal正确指出的那样,MySQL不喜欢在同一个表上使用子查询作为更新,但你可以很好地绕过它:
UPDATE $table
SET credit = 0
WHERE
credit='$credit'
AND statid='$statid'
AND userid='$userid'
AND ID = (select ID from (SELECT MAX(ID)as ID from $table) a)
我控制台上的例子:
mysql> select * from first;
+------+-------+
| id | title |
+------+-------+
| 1 | aaaa |
| 2 | bbbb |
| 3 | cccc |
| 4 | NULL |
| 6 | eeee |
+------+-------+
5 rows in set (0.00 sec)
mysql> update first set title='ffff' where id=(select max(id) from first);
ERROR 1093 (HY000): You can't specify target table 'first' for update in FROM clause
mysql> update first set title='ffff' where id=(select ID from (select max(id) as ID from first) a);
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from first;
+------+-------+
| id | title |
+------+-------+
| 1 | aaaa |
| 2 | bbbb |
| 3 | cccc |
| 4 | NULL |
| 6 | ffff |
+------+-------+
5 rows in set (0.00 sec)
注意:由于子查询技巧中的子查询解锁了原始表,因此最好在事务中运行它-如果表从查询中解锁,那么在更新时它可能已经更改-因此最好在交易中使用这种类型的查询。