2017-02-21 4 views
3

Есть ли способ извлечь ТОЛЬКО первую строку, которая поступает непосредственно после строк, содержащих type = 'Email'?SQL Server: Извлеките строки, которые появляются после строки, содержащей определенный текст

Пример таблицы:

id  type  details 
1 Email [email protected] 
2 1234 1234 
3 Email [email protected] 
4 12345 12345 
5 123456 123456 
6 Email [email protected] 
7 1234567  1234567 
8 12345678 12345678 
9 123456789 123456789 
10 Email [email protected] 
11 01  01 
12 Email [email protected] 
13 012  012 
14 Email [email protected] 
15

С Python и Панды, я хотел бы написать что-то вроде этого ...

indexes = table[table['type']=='Email'].index + 1 
table = table.ix[indexes] 

Где выход будет ...

2 1234 1234 
4 12345 12345 
7 1234567  1234567 
11 01 01 
13 012  012 
15

ответ

3
select * 

from (select * 
       ,lag (type) over (order by id) as prev_type 

     from t 
     ) t 

where prev_type = 'Email' 
+0

Удивительный! Спасибо Dudu - это отлично работает. –

+0

Что значит «лаг» ... есть ли ключевое слово или что-то еще? – Darshak

+0

lag - это функция, которую вы можете использовать для получения следующего значения –

1

Для SQL Server Запрос

select * from table where id in (Select id+1 from Table where type='Email') 
+0

Мне просто нужны первые строки, которые поступают непосредственно после type = Email –

+0

вы ищете это ..? – Darshak

+0

Погрешность, но для всех записей с типом = 'Электронная почта'. Он должен напоминать результат, который у меня есть в моем первоначальном посте. –

1

Если вы специально желая только первую запись после электронной почты подряд вы могли бы быть немного более избирательным, как это:

SELECT * FROM Table WHERE ID IN (SELECT ID+1 FROM Table where type='Email') 
+0

Просто заметил, что ваше поле называется ID, извините, отредактировано! – Conrad

+0

Спасибо, Конрад! Это отлично работает, если ID указан, но что делать, если он не указан. Есть ли обобщенный способ сделать это? –

+0

Вы считаете, что id не имеет пробелов –

0

Вот решение, которое должно работать, даже если идентификатор имеет пробелы. Он использует функции окна.

---Sample data 
WITH data([id], [type] , [details]) AS 
(
    SELECT 1,'Email','[email protected]' UNION ALL 
    SELECT 2,'1234', '1234' UNION ALL 
    SELECT 3,'Email','[email protected]' UNION ALL 
    SELECT 4,'12345','12345' UNION ALL 
    SELECT 5,'123456', '123456' UNION ALL 
    SELECT 6,'Email','[email protected]' UNION ALL 
    SELECT 7,'1234567', '1234567' UNION ALL 
    SELECT 8,'12345678', '12345678' UNION ALL 
    SELECT 9,'123456789','123456789' UNION ALL 
    SELECT 10, 'Email','[email protected]' UNION ALL 
    SELECT 11, '01','01' UNION ALL 
    SELECT 12, 'Email','[email protected]' UNION ALL 
    SELECT 13 , '012', '012' UNION ALL 
    SELECT 14 ,'Email','[email protected]' UNION ALL 
    SELECT 15 ,'0123', '0123' 
), 
---temporary table to hold row numbers 
tbl([Row_Num], [id], [type]) AS 
(
    SELECT (ROW_NUMBER() OVER (ORDER BY [id])) AS [Row_Num] ,[id],[type] FROM data 
) 

---actual query using both tables 
SELECT 
    d.[id], 
    d.[type], 
    d.[details] 
FROM [data] d 

INNER JOIN 

[tbl] t 

ON d.[id] = t.[id] 

WHERE t.[Row_Num] IN (SELECT Row_Num + 1 FROM tbl WHERE [type] = 'Email')