184 похожих чатов

Primary index используется для поиска с = и LIKE 'prefix%'

по строкам, но не используется для != и NOT LIKE , это так задумано?
версия 22.8.5.29

11 ответов

13 просмотров

во всех случаях используется PK если поля из PK в WHERE как проверяли что не используется?

ivan- Автор вопроса
Slach [altinity]
во всех случаях используется PK если поля из PK в ...

explain indexes = 1 запрос с where col = 'a' : PrimaryKey Parts: 0/3070, Granules: 0/4826 запрос с where col != 'a': PrimaryKey Parts: 3070/3070, Granules: 4826/4826

ivan
explain indexes = 1 запрос с where col = 'a' : Pr...

в обоих случаях показывает что PK использовался и в результате PK установили что во втором слуаче надо читать всю таблицу потому что col != a у вас равномерно по всем партам и всем гранулам размазан

ivan- Автор вопроса
Slach [altinity]
в обоих случаях показывает что PK использовался и ...

да, неудачный пример, сорри ) в оригинале другая колонка с другим распределением значений, сейчас переделаю )

ivan- Автор вопроса
Slach [altinity]
в обоих случаях показывает что PK использовался и ...

переделал да, для != всё хорошо, проблема только с NOT LIKE по префиксу, с чего всё собственно и началось https://fiddle.clickhouse.com/0e0680c3-d5d6-4e65-88fc-afc052acd284

ivan
переделал да, для != всё хорошо, проблема только с...

https://clickhouse.com/docs/en/engines/table-engines/mergetree-family/mergetree#functions-support должно поддерживаться думаю что стоит создать issue на github скиньте туда explain и ссылку на fiddle и ссылку на доку и спросите почему парты не отбрасываются

ivan- Автор вопроса
ivan
понял, спасибо

немного переделал https://fiddle.clickhouse.com/7ebf2abf-f126-42d8-9d2f-a3837af7371b (SelectExecutor): Key condition: unknown (SelectExecutor): Selected 3/3 parts by partition key, 3 parts by primary key, 36/36 marks by primary key, 36 marks to read from 3 ranges Думаю основная причина в этом это странно. явно какой то баг

Slach [altinity]
немного переделал https://fiddle.clickhouse.com/...

да с чего баг-то? нельзя в дереве найти not like и != тоже нельзя, только скан колонки, что и будет в этом случае

ivan- Автор вопроса
Denny [Altinity]
да с чего баг-то? нельзя в дереве найти not like и...

с != индекс используется https://fiddle.clickhouse.com/88782b9c-0826-4213-a79a-5a95b356ffa4 а почему нельзя NOT LIKE 'a%' реализовать через исключение гранул между двумя метками, если они обе LIKE 'a%'?

Denny [Altinity]
да с чего баг-то? нельзя в дереве найти not like и...

там not like с префиксом... != кстати работает и парты отсекает ссылку на доку я привел в которой сказано обратное

Похожие вопросы

Обсуждают сегодня

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
всем трям! Кто-нибудь работал со связкой werf + harbor + trivy ? Во время сборки образа выходит ошибка "PROJECTPOLICYVIOLATION: current image with "Pending" status of vulnerab...
Авессалом
11
> комьюнити я бы не судил по этому чату. Как мы видели по статам просмотров нескольких телеговских постов, то в чате их набивается 30-40 или даже выше, когда как общаются акти...
Constantin F.
4
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Как сделать чтобы short точно был 2 байта, int точно 4 байта ?(без стандартных библиотек, ну типа без int16_t, int32_t)
#
8
Всем привет. Испытываю проблемы в работе БД, а именно огромного роста логов, такого характера: 024-05-16 18:39:07 +05 sentry sentry [unknown] 1050169 7-1 app-sentry01.corp.ru>...
Alexey
2
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Только такой if ($modx->event->name == 'OnBeforeCartItemAdding') { $meta = $params['item']['meta']; $lang = $modx->getConfig('_lang'); // проверяем, задана ли опция i...
Multi Web
1
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Карта сайта