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

Всем добрый день. Поделитесь пожалуйста опытом ))) Вот есть у

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

Может есть еще что-то, что не вижу и можно оптимизаровать?

2 ответов

8 просмотров
WoodyFire- Автор вопроса

Да вот еще по справочным таблицам. Так как все значения символьного типа, то целесообразно их будет запихнуть в одну справочную таблицу и в отдельном поле дать идентификатор (из второй таблице) к какому фильтру относиться данное значение. А во второй таблице прописать наименование фильтров. Мысли верны?

> Схему данных пока не сильно менял. Может, с этого стоит, наоборот, начать? > Сейчас главное чтоб работало на PostgreSQL, а не на MySQL. А то потом может прийтись в "работающем" данные править постфактум. :( > Но все равно глаза говорят оптимизировать надо бы данную функцию. А мои глаза хотят её развидеть. ;(

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

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

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
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
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Я тут за тем, чтобы задать вопрос, так как не знаю ассемблер, учу с/с++. Короче, насколько дорога операция перехода в функцию при ее вызове? Дело в том, что в с++ есть макросы...
Максим Рябцев
12
Привет, нужен совет старших товарищей. Есть глобальная переменная var DefaultDataFolder:string; инициализируем DefaultDataFolder:='a:\_OUT\'; есть примитивная процедур...
Max Otto
14
А какие чаты вообще в ходу? Auto aim? И что еше
do you think you're better off alone? А
13
hello friends. Do you know how can I learn getx? I have a software project that I should deliver it up to 5 weeks later and I need to learn firebase too. I will be thankfull
AmirHossein Razavi
15
Карта сайта