如何选择MySQL表中的最后一行?

我正在插入数据,我需要从前一行检索一个列值。

表中有一个auto_increment。


当前回答

在一个查询中没有ID:

SELECT * FROM table_name LIMIT 1 OFFSET (SELECT COUNT(*) - 1 FROM table_name)

其他回答

在一个查询中没有ID:

SELECT * FROM table_name LIMIT 1 OFFSET (SELECT COUNT(*) - 1 FROM table_name)

这里的许多答案都是相同的(根据自动增量排序),这是可以的,前提是您有一个索引的自递增列。

另一方面,如果您有这样的字段并且它是主键,那么使用order by与select max(id)相比没有性能损失。主键是数据在数据库文件中的排序方式(至少对于InnoDB), RDBMS知道数据的结束位置,它可以通过id + limit 1优化顺序,使其与达到最大值(id)相同。

现在较少有人走过的路是当你没有自增主键时。也许主键是一个自然键,它是3个字段的组合…… 不过,也不是一切都完了。从编程语言中,您可以首先使用

SELECT Count(*) - 1 AS rowcount FROM <yourTable>;

然后在LIMIT子句中使用得到的数字

SELECT * FROM orderbook2
LIMIT <number_from_rowcount>, 1

不幸的是,MySQL不允许在LIMIT子句中使用子查询或用户变量

几乎每个数据库表都有一个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);

你可以在LIMIT命令中使用OFFSET:

SELECT * FROM aTable LIMIT 1 OFFSET 99

如果您的表有100行,则返回最后一行而不依赖于主键

SELECT * FROM adds where id=(select max(id) from adds);

此查询用于获取表中的最后一条记录。