Поведение, которое я хочу реплицировать, похоже на grep с флагами -A
и -B
.
например, grep -A 2 -B 2 "hello" myfile.txt
даст мне все строки, которые имеют "привет" в них, но также 2 строки до и 2 строки после него.
Предположим, что эта схема таблицы:
+--------+-------------------------+
| id | message |
+--------+-------------------------+
| 1 | One tow three |
| 2 | No error in this |
| 3 | My testing message |
| 4 | php module test |
| 5 | hello world |
| 6 | team spirit |
| 7 | puzzle game |
| 8 | social game |
| 9 | stackoverflow |
|10 | stackexchange |
+------------+---------------------+
Теперь запрос вроде:
Select * from theTable where message like '%hello%'
приведет к:
5 | hello world
Как я могу поместить другой параметр "N", который выбирает N строк раньше, и N строк после согласованной записи, т.е. для N = 2, результат должен быть:
| 3 | My testing message |
| 4 | php module test |
| 5 | hello world |
| 6 | team spirit |
| 7 | puzzle game |
- Для простоты предположим, что "как% TERM%" соответствует только 1 строке.
- Здесь результат должен быть отсортирован в поле auto-increment
id
.