меня старая функция написанная в MySQL (писалась она давно и на скорую руку лишь бы считала) работала несколько лет исправно и я ее не трогал. Сейчас при переезде на PosrgreSQL ее переписываю. Схему данных пока не сильно менял. Сейчас главное чтоб работало на PostgreSQL, а не на MySQL.
Но все равно глаза говорят оптимизировать надо бы данную функцию.
https://pastebin.com/BcXL6myD
Как я вижу так:
1. формулы какие прописаны необходимо вынести в отдельные функции и из этой функции вызывать. Это позволит использовать формулы в других процедурах и функциях, если потребуется. Да и изменив одну из формул - вычисления изменяться везде, где используется эта формула.
2. справочные данные для фильтров - вынести в отдельные справочные таблицы и при выполнении фильтрации запрашивать значения из таблиц. Тогда можно будет без переписывания функции изменять фильтры. Достаточно добавить или удалить значения в справочных таблицах.
Может есть еще что-то, что не вижу и можно оптимизаровать?
Да вот еще по справочным таблицам. Так как все значения символьного типа, то целесообразно их будет запихнуть в одну справочную таблицу и в отдельном поле дать идентификатор (из второй таблице) к какому фильтру относиться данное значение. А во второй таблице прописать наименование фильтров. Мысли верны?
> Схему данных пока не сильно менял. Может, с этого стоит, наоборот, начать? > Сейчас главное чтоб работало на PostgreSQL, а не на MySQL. А то потом может прийтись в "работающем" данные править постфактум. :( > Но все равно глаза говорят оптимизировать надо бы данную функцию. А мои глаза хотят её развидеть. ;(
Обсуждают сегодня