2

我有一个看起来像这样的表:

ID  | Time  | Metadata
======================
1   | 01:00 | Foo
2   | 02:00 | Foo
3   | 03:00 | Foo
4   | 04:00 | Bar
5   | 05:00 | Bar
6   | 06:00 | Bar
7   | 07:00 | Foo
8   | 08:00 | Foo
9   | 09:00 | Foo
10  | 10:00 | Foo
11  | 11:00 | Foo
12  | 12:00 | Foo

我想获得元数据更改的所有第一个实例,如下所示:

ID  | Time  | Metadata
======================
1   | 01:00 | Foo
4   | 04:00 | Bar
7   | 07:00 | Foo

GROUP BY会将第 1 行和第 7 行组合在一起,这不是我想要的。我可以在 SQL 之外执行此操作,但这需要我想避免的大量数据选择。

4

3 回答 3

0

另一种方法

SELECT id, `time`, metadata
FROM 
(select @cnt := 0, @previous := '' from dual) dummy
join (

  SELECT  id, `time`,
      metadata, @cnt := IF(metadata = @previous, @cnt + 1, 1) occurence,
      @previous := metadata FROM trytable

) a where occurence = 1;

在这里演示

于 2013-08-08T18:18:04.823 回答
0
select t11.*
from test1 t11
where 
t11.metadata <> (select t12.metadata from test1 t12
                 where t11.id > t12.id
                 order by t12.id desc
                 limit 1
                )
or not exists (select 1 from test1 t13
               where t11.id > t13.id)
order by id

在这里演示

于 2013-08-08T18:13:19.400 回答
0

我认为最简单的方法是创建一个存储过程并在其中执行“元数据更改”逻辑。存储过程会将游标返回到您需要的集合。这样您就不会向客户端获取大量数据并在客户端上进行处理。

于 2013-08-08T17:49:42.843 回答