如何选择MySQL表中的最后一行?
我正在插入数据,我需要从前一行检索一个列值。
表中有一个auto_increment。
如何选择MySQL表中的最后一行?
我正在插入数据,我需要从前一行检索一个列值。
表中有一个auto_increment。
当前回答
简单地使用:PDO::lastInsertId
http://php.net/manual/en/pdo.lastinsertid.php
其他回答
简单地使用:PDO::lastInsertId
http://php.net/manual/en/pdo.lastinsertid.php
在有很多行的表上,两个查询可能更快…
SELECT @last_id := MAX(id) FROM table;
SELECT * FROM table WHERE id = @last_id;
你可以将@spacepille建议的两个查询组合成一个查询,看起来像这样:
SELECT * FROM `table_name` WHERE id=(SELECT MAX(id) FROM `table_name`);
它的工作速度应该非常快,但在INNODB表上,它比ORDER+LIMIT慢了几分之一毫秒。
是的,这里有一个auto_increment
如果您想要的是表中所有行的最后一行,那么现在正是MAX(id)是正确答案的时候!一种:
SELECT fields FROM table ORDER BY id DESC LIMIT 1;
几乎每个数据库表都有一个auto_increment列(通常是id)
如果你想要表中的最后一行,
SELECT columns FROM table ORDER BY id DESC LIMIT 1;
OR
你可以将两个查询组合成一个查询,就像这样:
SELECT columns FROM table WHERE id=(SELECT MAX(id) FROM table);