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

Есть, значит, база, структуру которой не могу поменять. И там

сделано хрен пойми зачем так:

Есть парентИтем, есть итем, есть мейнКатегори, сабКатегори и отдельная таблица, которая хранит строки с именами для всего вышеперечисленного. Все в разных таблицах

И мне всю эту шляпу надо отдавать на фронт, да побыстрее. Но из-за кучи джойнов все работает неприемлимо долго

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

5 ответов

8 просмотров

вопервых я бы сначала посмотрел из-за чего медленно

R- Автор вопроса
Denisio 🇬🇪
вопервых я бы сначала посмотрел из-за чего медленн...

Из-за того, что таблиц много. Логики особо нет никакой, надо просто взять из базы и в джсончик Данные эти - меню стороннего ресторана, ну и запросы частые очень, так как пагинация есть. 10 записей отдаю за 2 секунды, люди устают ждать на той стороне 😅

>10 записей отдаю за 2 секунды Анализ запроса делался? Точно дело в "множестве таблиц"? Вроде их не больше 10 тут

R- Автор вопроса
Andrew Shurunov
>10 записей отдаю за 2 секунды Анализ запроса дела...

Я человек простой, вижу таблицы - джойню 😅 Хз что за анализ запроса, но там реально все просто: 1.Сначала беру парент итем, джойню с итем, джойню с 2 таблицами категорий 2.Материализую все это дело 3. Достаю айдишники имен (хз как за селект создать один лист сразу со всеми нужными данными. Поэтому по листу прохожу 4 раза) 4. Джойню таблицу с текстом с айдишниками, результат запихиваю в дикшенари: ключ айдишник, значение имя 5. Затем все данные соединяю в нужном виде и отправляю Код не могу скинуть, хлопнул крышкой ноутбука и ушел остывать 😂

R- Автор вопроса
R
Я человек простой, вижу таблицы - джойню 😅 Хз что...

Ну и это все еф и линк, sql пока не выучил 😂

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

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

Ребят в СИ можно реализовать ООП?
Николай
32
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Кстати, что за тип булеана, который в памяти как 00 для фолса и 01 для тру отображается? Однобайтовый
Serjone
8
Коллеги, я тут для личных нужд пошел ставить MQTT сервер, пощупал mosquitto, но ужаснулся отсутствию такой банальности, как HTTP API для посмотреть список топиков. А тут что,...
Maksim Lapshin
14
Карта сайта