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

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

27 ответов

44 просмотра

Это сказки, тебе надо просто разобраться с запросами со скоростью их выполнения по одному. Найди запрос который тебя не устраивает по времени и присылай его текст а также 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, записать продукт с идентификатором бренда Чего именно не хватает для этой операции, и почему ее (информации) нет во входном файле

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

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

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
2
Привет!) Кто как юзает переменные в строках?) Чисто ради интереса Вот так: echo "У меня {$bananasAmount} бананов"; Или вот так: echo "У меня ${bananasAmount} бананов";
Виталий
3
разработчик ботов скидывает портфолио, боты которые он уже создал. А вот как узнать что это именно он их создал?
Gosudar
4
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
кто-нибудь уже пробовал это?
Lencore
4
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
❓ Подскажите как сделать в группе телеги функцию (кнопку) пересылки сообщения где есть нарушение правил? Бот к каждому сообщению (по определенным ключам) добавляет снизу кнопк...
Alexander
4
Вопрос: Здравствуйте! У меня возникла проблема с использованием плагина Mall в OctoberCMS. Я использую все файлы и компоненты в их исходном виде, без изменений. Однако на стр...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
8
Карта сайта