Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Попасть в индекс при использовании replace 
:(
    Опции темы
polin11
Дата 2.12.2018, 06:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 122
Регистрация: 6.6.2015

Репутация: нет
Всего: нет



Использую СУБД Postgresql
Есть индекс по полю Код и индекс по условию lower("Код")
В запросах 
Код

select *
from "Коды"
where "Код" like 'Оди%'
select *
from "Коды"
where lower("Код") like 'Оди%'

Попадаю в нужные индексы. 
Проблема возникает при желании удалить пробелы: 
Код

select *
from "Коды"
where replace("Код", ' ','') like 'Оди%'
select *
from "Коды"
where replace(lower("Код"), ' ','') like 'Оди%'

Как правильно создать индекс, чтобы использовался в 2 проблемных запросах?
PM MAIL   Вверх
Akina
Дата 2.12.2018, 22:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 3
Всего: 453



Цитата(polin11 @  2.12.2018,  07:18 Найти цитируемый пост)
индекс по условию lower("Код")

Это индекс по выражению.

Цитата(polin11 @  2.12.2018,  07:18 Найти цитируемый пост)

Как правильно создать индекс, чтобы использовался в 2 проблемных запросах? 

Нужно создавать индекс именно по используемому выражению. Например, для первого запроса по выражению replace(lower("Код"), ' ','').


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PostgreSQL | Следующая тема »


 




[ Время генерации скрипта: 0.1415 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.