Всем привет, имеется проект в котором идут небольшое кол-во паралельных

запросов в 1 таблицу, заметил что при каждой выборке запрос работает все медленней и медленней, может подсказать в какую сторону копать?

27 ответов

20 просмотров

Это сказки, тебе надо просто разобраться с запросами со скоростью их выполнения по одному. Найди запрос который тебя не устраивает по времени и присылай его текст а также ddl таблиц которые участвуют в запросе Ну и в конце вопрос Что тебя не устраивает Почему и описание

为什么要翻译-. Автор вопроса
Ilya Zviagin
Это сказки, тебе надо просто разобраться с запроса...

Запрос в некотором роде простой, у нас есть таблица брендов (в ней 19 759 262 записей), запрос идет такого рода: SELECT id, name, FROM brands WHERE name IN (тут может быть до 10тыс элементов) AND platfrom_id = ? DDL таблицы: create table brands ( id int unsigned auto_increment primary key, name varchar(255) not null, url text null, created_at timestamp null, updated_at timestamp null, external_id bigint unsigned null, platform_id int unsigned null ) collate = utf8mb4_unicode_ci; create index brand_name on brands (name); create index brands_external_id_index on brands (platform_id, external_id); create index brands_id_index on brands (id); create fulltext index brands_name_index on brands (name);

为什么要翻译 .
Запрос в некотором роде простой, у нас есть таблиц...

Ну это херовый запрос. Если у тебя в ин 10.000 записей твой запрос будет возвращать примерно 10.000 записей. Это никому не нужно соответственно тебе надо выбросить этот запрос и писать другой Запрос который бы выбирал те данные которые реально нужны пользователю по реальным критериям поиска

为什么要翻译-. Автор вопроса
Ilya Zviagin
Ну это херовый запрос. Если у тебя в ин 10.000 зап...

Проблема в том что это идет импорт товаров раз в 24 часа, мне дается файлик где 10тыс строк, где просто названиями указано названия бренда, для правильной связи мне нужно находить идентификатор который есть в базе, если есть советы как сделать правильней, то подскажи)

为什么要翻译 .
Запрос в некотором роде простой, у нас есть таблиц...

Ну и нужного индекса у тебя нет для этого запроса нужен индекс name, платформа ID

为什么要翻译 .
Проблема в том что это идет импорт товаров раз в 2...

Если это импорт товаров Ничего страшного что там он будет долгим этот запрос а быстрым он не будет потому что 10.000 записей

为什么要翻译 .
Проблема в том что это идет импорт товаров раз в 2...

Если тебе нужно находить какие-то связи - это джоин, Но у тебя его нету в запросе поэтому я тебе ничего сказать про это не могу Я ничего не понял

为什么要翻译-. Автор вопроса

Грубо говоря, у меня есть файл, в котором содержаться характеристики товаров, например возьмем бренд, в самом файле он имеет строковое значение, для того чтобы мне импортировать товар, мне нужно переставить строку на идентификатор бренда, из-за этого я выбираю сразу 10тыс, пробовал делать по 250, но результат все тот-же

为什么要翻译 .
Грубо говоря, у меня есть файл, в котором содержат...

почему сначала не импортировать сырые данные без обработки во временные таблицы .. а потом уже выполнять доб обработку ?

Vitaly Larin
почему сначала не импортировать сырые данные без о...

Так там нету пока никакой дополнительной обработки

为什么要翻译-. Автор вопроса
Ilya Zviagin
Так там нету пока никакой дополнительной обработки

Грубо говоря дополнительная обработка, это поиск по имени бренда и перестановка его на идентификатор бренда

为什么要翻译 .
Грубо говоря дополнительная обработка, это поиск п...

Ну покажи запрос и таблицы тогда будем обсуждать

Ilya Zviagin
Так там нету пока никакой дополнительной обработки

у него явно есть ... он сначала берет данные их файла . .потом лепит их в запрос в IN и фигачит этот километроый запрос в БД .. и потом уже данные оттуда использует дальше

为什么要翻译-. Автор вопроса
Vitaly Larin
у него явно есть ... он сначала берет данные их фа...

Да, так и происходит, а какой вариант предлагаете вы?

为什么要翻译 .
Да, так и происходит, а какой вариант предлагаете ...

Я предлагаю чтобы мы не гадали Что там у тебя происходит Ты должен прислать эти запросы и описание таблиц

为什么要翻译-. Автор вопроса
为什么要翻译 .
Запрос в некотором роде простой, у нас есть таблиц...

Так вот же я скидывал) Или что-то другое нужно?

为什么要翻译 .
Да, так и происходит, а какой вариант предлагаете ...

уже предложили .. не IN а JOIN и отделить загрузку от обработки

为什么要翻译-. Автор вопроса
为什么要翻译 .
Так вот же я скидывал) Или что-то другое нужно?

Тогда Расскажи что это за запрос и для чего он используется Вот тут ты писал всякое Грубо говоря, у меня есть файл, в котором содержаться характеристики товаров, например возьмем бренд, в самом файле он имеет строковое значение, для того чтобы мне импортировать товар, мне нужно переставить строку на идентификатор бренда, из-за этого я выбираю сразу 10тыс, пробовал делать по 250, но результат все тот-же Тут никакого поиска бренда по имени и пацановке его идентификатора нет

为什么要翻译-. Автор вопроса
Ilya Zviagin
Тогда Расскажи что это за запрос и для чего он исп...

Мне приходит файл, который содержит продукты. Я пробегаю по этому файлу и собираю названия брендов После того как я полностью пробежался по всем товара в файле, то я отправляю запрос SELECT id FROM brands WHERE name IN (тут может быть до 10тыс названия) AND platform_id = ? Это мне нужно для того чтобы потом в другую таблицу products, записать продукт с идентификатором бренда

为什么要翻译-. Автор вопроса
Ilya Zviagin
Но бренды же В каждой строчке разные...

Не всегда, могут быть одинаковые бренды у разных товаров, по этому я отправляю только уникальные названия

为什么要翻译 .
Не всегда, могут быть одинаковые бренды у разных т...

Ну хорошо Почему бы не залить весь файл товаров в базу данных например во временную таблицу и затем уже с ним в этой таблице разбираться искать бренды и всё такое

为什么要翻译-. Автор вопроса
Ilya Zviagin
Ну хорошо Почему бы не залить весь файл товаров в ...

Вот до этого я не додумался) Звучит как хороший вариант, просто хотел услышать и другие методы решения для текущей задачи, но на ум пришла только пихать все названия в запрос

为什么要翻译 .
Мне приходит файл, который содержит продукты. Я п...

Попробуй идти от >> Это мне нужно для того чтобы потом в другую таблицу products, записать продукт с идентификатором бренда Чего именно не хватает для этой операции, и почему ее (информации) нет во входном файле

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

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

Кто создает тут ботов для телеграмм групп ?
Antskup
8
Я хочу запустить свой проект в тг. Что-то между пирамидой и майнилкой. Еще подобного ничего не было. Уникальная идея. Нужен именно не бот, а приложение. С ввод, выводом тон...
Павел А.
6
Привет, кто может сделать юзербота с апи? Задачи: - создавать группы - создавать каналы - задавать для созданных каналов аватарку или эмоджи, имя группы - добавлять в группы...
Lencore
13
Всем доброго вечера! Хочу поделиться своим злоключением с человеком, который, как оказалось сюда тоже скидывал свое резюме. Жаль, что я вашу группу не нашел раньше… человек ки...
Роман Ахмедзянов
4
Я колись ставив гуглу антиспам 3.0, може і норм, але мені не дуже зайшло. Теж думав тиждень, що його і куди. Зупинився на трех варіантах відразу всі три і включив 1. Перевір...
𝓔𝓾𝓰𝓮𝓷𝓮𝓥 J
2
господа, когда у вас в боте есть локализация (ру + англ, остальные языки пока не планируются), вы на первом старте как с языком решаете вопрос: смотрите на language_code приле...
Denis 🐍|👑 | darling! 🥰
5
Всем привет, Добавил в плагин определение user agent public function registerMarkupTags() { return [ 'filters' => [ 'staticPage' => ['RainLab\Pages\Cl...
John Norton Kruger
3
где собака, админ группы? нычкуется и боится проявить волю, в толерантность еще не наигрался? @yelizariev
Ognezar
61
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
А чего при переходе с 2 на 3 все что в билдере сделано тютю?
Денис Александрович
5
Карта сайта