У меня много временных диапазонов в таблице TimeRanges:
StartTime EndTime
2010-01-01 06:00 2010-01-01 18:00
2010-01-01 20:00 2010-01-01 22:00
2010-01-02 06:00 2010-01-02 18:00
2010-01-02 20:00 2010-01-02 22:00
2010-01-03 06:00 2010-01-03 18:00
2010-01-03 20:00 2010-01-03 22:00
2010-01-04 06:00 2010-01-04 18:00
2010-01-04 20:00 2010-01-04 22:00
...
...
2010-02-01 06:00 2010-02-01 18:00
2010-02-01 20:00 2010-02-01 22:00
2010-02-02 06:00 2010-02-02 18:00
2010-02-02 20:00 2010-02-02 22:00
2010-02-03 06:00 2010-02-03 18:00
2010-02-03 20:00 2010-02-03 22:00
2010-02-04 06:00 2010-02-04 18:00
2010-02-04 20:00 2010-02-04 22:00
...
...
2011-01-01 06:00 2011-01-01 18:00
2011-01-01 20:00 2011-01-01 22:00
2011-01-02 06:00 2011-01-02 18:00
2011-01-02 20:00 2011-01-02 22:00
2011-01-03 06:00 2011-01-03 18:00
2011-01-03 20:00 2011-01-03 22:00
2011-01-04 06:00 2011-01-04 18:00
2011-01-04 20:00 2011-01-04 22:00
...
...
2011-02-01 06:00 2011-02-01 18:00
2011-02-01 20:00 2011-02-01 22:00
2011-02-02 06:00 2011-02-02 18:00
2011-02-02 20:00 2011-02-02 22:00
2011-02-03 06:00 2011-02-03 18:00
2011-02-03 20:00 2011-02-03 22:00
2011-02-04 06:00 2011-02-04 18:00
2011-02-04 20:00 2011-02-04 22:00
и у меня есть несколько фильтров в таблице TimeFilters:
StartTime EndTime
2010-02-01 00:00 2010-03-01 00:00
2011-02-01 00:00 2011-03-01 00:00
2012-02-01 00:00 2012-03-01 00:00
Мне нужно удалить записи из таблицы TimeRanges, будут сохранены только те временные диапазоны, которые находятся в таблице TimeFilters.
Проще говоря, я хочу сохранить следующие записи:
с 2010-02-01 00:00 до 2010-03-01 00:00, например:
2010-02-01 06:00 2010-02-01 18:00
2010-02-01 20:00 2010-02-01 22:00
2010-02-02 06:00 2010-02-02 18:00
2010-02-02 20:00 2010-02-02 22:00
2010-02-03 06:00 2010-02-03 18:00
2010-02-03 20:00 2010-02-03 22:00
2010-02-04 06:00 2010-02-04 18:00
2010-02-04 20:00 2010-02-04 22:00
с 2011-02-01 00:00 до 2011-03-01 00:00, например:
2011-02-01 06:00 2011-02-01 18:00
2011-02-01 20:00 2011-02-01 22:00
2011-02-02 06:00 2011-02-02 18:00
2011-02-02 20:00 2011-02-02 22:00
2011-02-03 06:00 2011-02-03 18:00
2011-02-03 20:00 2011-02-03 22:00
2011-02-04 06:00 2011-02-04 18:00
2011-02-04 20:00 2011-02-04 22:00
Теперь я могу выбрать те записи, которые находятся внутри TimeFilters, во временную таблицу, затем обрезать таблицу TimeRanges и вернуть записи из временной таблицы, но это довольно много времени.