首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >返回序列号列表的3条最新记录

返回序列号列表的3条最新记录
EN

Stack Overflow用户
提问于 2014-10-15 13:42:59
回答 2查看 46关注 0票数 1

这是我的序列号表格的精简副本。

代码语言:javascript
复制
id            serial number
---------------------------
1064    1012507994
1065    1012507994
1067    1019527101
1436    1012507994
1437    1012507994
1438    1012507994
1439    1012507994
1464    1019527101
1465    1019527101

每次我向这个表中添加新的记录时,id都会递增。我希望能够传入一个serial_numbers列表,并获得我传入的每个序列号的最后3个id。我知道如何返回一个序列号的最后3个id,但我不知道现在如何获取序列号列表的最后3个id。

例如:我想获取序列号为(12507994,19527101)的最后(最近)3条记录,结果应该是

代码语言:javascript
复制
1439    12507994
1438    12507994
1437    12507994
1067    19527101
1464    19527101
1465    19527101
EN

回答 2

Stack Overflow用户

发布于 2014-10-15 16:14:35

您需要1。请选择最后2个序列号。2. SElect此数字的最后3条记录

代码语言:javascript
复制
SELECT   * 
FROM you_table
WHERE SERIAL number IN 
  (SELECT serial_number FROM you_table ORDER BY id DESC LIMIT 1, 1) 
LIMIT 0, 3 
UNION
SELECT * 
FROM you_table
WHERE SERIAL number IN 
  (SELECT serial_number FROM you_table ORDER BY id DESC LIMIT 0, 1) 
LIMIT 0, 3 
票数 1
EN

Stack Overflow用户

发布于 2014-10-15 14:03:59

最简单的方法是使用UNION:

代码语言:javascript
复制
SELECT * FROM your_table WHERE serial_number = '12507994' ORDER BY id DESC LIMIT 0,3
UNION
SELECT * FROM your_table WHERE serial_number = '19527101' ORDER BY id DESC LIMIT 0,3
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26375255

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档