|
|
|
Условие по дате с указанием диапазона и партиции
|
|||
|---|---|---|---|
|
#18+
Есть партицирование по дате (по месяцам) в таблице "3_GDP". Есть запрос к примеру: Код: plsql 1. 2. 3. 4. 5. Как видно, по дате джоин двух таблиц. Но смысл не в том. Смысл в том, что в данном случае выполняет скан все партиций таблицы "3_GDP". Вроде как логично. Потому как в случае условия равенства не известно в какой партиции может быть искомое значение. Но стоит добавить в запрос условие по дате для "3_GDP", как поиск уже идет по партициям от указанной даты. Код: plsql 1. 2. 3. 4. 5. А тут планировщик понял, что поиск нужно начинать с указанного условия даты. Пара вопросов: 1. Это особенность работы партицирования в Postgres? Тогда как он понимает что в случае условия "><" необходимо отбросить партиции для скана, которые заведомо не соответствую условию. 2. Это особенность планировщика, которые при условии равенства "=" не исключает скан партиций которые "<>" данного условия? Или это я не до конца вник? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.07.2014, 12:29:13 |
|
||
|
|

start [/forum/topic.php?fid=53&msg=38704746&tid=1998567]: |
0ms |
get settings: |
7ms |
get forum list: |
12ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
48ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
42ms |
get tp. blocked users: |
1ms |
| others: | 214ms |
| total: | 340ms |

| 0 / 0 |
