愚蠢的SQL问题。我有一个这样的表(“ pid”是自动递增的主列)
CREATE TABLE theTable (
`pid` INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
`timestamp` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
`cost` INT UNSIGNED NOT NULL,
`rid` INT NOT NULL,
) Engine=InnoDB;
实际表数据:
INSERT INTO theTable (`pid`, `timestamp`, `cost`, `rid`)
VALUES
(1, '2011-04-14 01:05:07', 1122, 1),
(2, '2011-04-14 00:05:07', 2233, 1),
(3, '2011-04-14 01:05:41', 4455, 2),
(4, '2011-04-14 01:01:11', 5566, 2),
(5, '2011-04-14 01:06:06', 345, 1),
(6, '2011-04-13 22:06:06', 543, 2),
(7, '2011-04-14 01:14:14', 5435, 3),
(8, '2011-04-14 01:10:13', 6767, 3)
;
我想获取每个rid的最新行的PID(每个唯一的RID 1个结果)。对于样本数据,我想:
pid | MAX(timestamp) | rid
-----------------------------------
5 | 2011-04-14 01:06:06 | 1
3 | 2011-04-14 01:05:41 | 2
7 | 2011-04-14 01:14:14 | 3
我尝试运行以下查询:
SELECT MAX(timestamp),rid,pid FROM theTable GROUP BY rid
我得到:
max(timestamp) ; rid; pid
----------------------------
2011-04-14 01:06:06; 1 ; 1
2011-04-14 01:05:41; 2 ; 3
2011-04-14 01:14:14; 3 ; 7
返回的PID始终是RID的PID的首次出现(行/ pid 1是第一次使用rid 1,行/ pid 3是第一次使用RID 2,行/ pid
7是第一次使用rid 3 )。尽管返回每个rid的最大时间戳,但pid并不是原始表中时间戳的pid。什么查询可以给我我想要的结果?
(在PostgreSQL 9中测试过)
标识摆脱和时间戳。
select rid, max(timestamp) as ts
from test
group by rid;
1 2011-04-14 18:46:00
2 2011-04-14 14:59:00
加入吧。
select test.pid, test.cost, test.timestamp, test.rid
from test
inner join
(select rid, max(timestamp) as ts
from test
group by rid) maxt
on (test.rid = maxt.rid and test.timestamp = maxt.ts)
问题内容: 我想做的是: 在我看来,该语句的语义首先是数据库将关闭,并为我确定全部中最大的价值是什么。然后,它将对该值加1,并将结果值分配给具有1、3、5、6和8 的行的列。似乎足够简单… 但是,当我尝试运行该查询时,MySQL对此kes之以鼻,说: 要获得我想要的结果,您必须使用什么秘诀? 问候,维克 问题答案: 尝试
在编写CSS媒体查询时,有没有什么方法可以用“或”逻辑指定多个条件? 我正在尝试这样做:
问题内容: 在将其标记为重复之前,请先看一下此SQLFiddle。 我有这个架构: 子查询: 结果: 现在,这里最棘手的部分是此查询的结果: 这是: 应该是这样的: 您认为查询中有什么问题? 问题答案: 而不是您可以简单地使用相同。也可以改用。 输出: 看到这个SQLFiddle 编辑: 如果要使用它,则必须使用如下子查询: 看到这个SQLFiddle 编辑2: 除了在外部查询中使用之外,您也可以
问题内容: 我正在尝试计算表中的最大值以及该表中的其他值。但是,我为此做的表不是“真实”表,而是由子查询生成的表。这给我带来了问题,因为我认为如果不重新指定整个子查询就无法两次加入它。 我目前有一个SQL Server解决方案,使用,但我正在寻找与DBMS无关的版本,因为该项目的单元测试在不具有此功能的Sqlite DB中运行。 如果它们有用,这是架构和我的SQL Server特定查询: Cour
前面我们介绍了如何使用 SELECT、INSERT、UPDATE 和 DELETE 语句对 MySQL 进行简单访问和操作。下面在此基础上开始学习子查询。 子查询是 MySQL 中比较常用的查询方法,通过子查询可以实现多表查询。 子查询指将一个查询语句嵌套在另一个查询语句中。子查询可以在 SELECT、UPDATE 和 DELETE 语句中使用,而且可以进行多层嵌套。在实际开发时,子查询经常出现在
问题内容: 我将使用Sencha Touch将Android-Travellog应用程序移植到其他Plattforms。问题是,Sencha仅具有一个存储系统来存储数据,而似乎没有可能正确地进行MySql查询。而且,由于我以前的应用程序中的大多数Mysql代码已经存在,因此使用Senchas new System重做所有内容时,id会很痛苦。是否可以在Sencha中使用mysql(或任何其他sql