有没有办法从MySQL表中获取最后N行而不使用自动增量字段或时间戳?

时间:2016-01-08 06:05:39

标签: mysql

stackoverflow本身有很多解决方案,其目标是使用自动增量字段或时间戳读取表的最后n行:例如,以下查询从名为tab的表中获取最后10个记录名为id的字段值的降序,它是表中的自动增量字段:

Select * from tab order by id desc limit 10

我的问题是:是否有任何替代方法,无需获得自动增量字段或时间戳来完成任务以获得相同的输出?

提示:提出这个问题的动机来自以下事实:我们将记录存储到表中,并在使用简单查询查询数据库时未指定任何标准,如:

Select * from tab

然后输出的顺序与插入表中的记录顺序相同。那么有没有办法按照与输入数据库相反的顺序获取记录?

2 个答案:

答案 0 :(得分:6)

mysql中的数据未被订购 - 除非您在查询中指定order by,否则您对所获得的记录顺序没有任何保证。

所以不,除非你按时间戳,身份证或任何其他字段订购,否则你无法得到最后一行,只是因为没有订单没有'最后'

答案 1 :(得分:4)

  

在SQL世界中,顺序不是一组数据的固有属性。   因此,您的RDBMS无法保证您的数据会来   除非你,否则按照一定的顺序 - 或者甚至以一致的顺序 - 返回   使用ORDER BY子句查询数据。

因此,如果您没有按某些ID或某些列排序的数据,则无法根据其排序跟踪数据。因此无法保证MYSQL如何存储数据,因此无法获得最后n条记录。

您还可以查看article

  

<强>注意事项

     

行的排序

     

如果没有ORDER BY,记录可能会以不同的方式返回   订单比以前的MEMORY实施。

     

这不是错误。任何依赖于特定订单的应用程序   ORDER BY子句可能会产生意外结果。特定订单   没有ORDER BY是存储引擎和查询的副作用   优化器实现可能会在次要MySQL之间发生变化   版本。