- Тоесть вы хотите самостоятельно, повторно, анализировать план запроса который сг, ыы (?), 21:56 , 07-Апр-22 (1) +2
> Уважаемые, доброго дня! > У меня свой самописный "фреймворк" назовём его так, и там соответственно свой > класс для работы с БД MySQL, средства отладки и прочие личные > хотелки. > Так вот, я хочу иметь возможность все генерируемые SQL запросы при включении > дебага - чтобы автоматом проверялись на всякие SQL минусы. Типа того, > что там например индексы не используются, или временная таблица на диске > создалась... Я на самом деле просто в глубинах SQL не так > силён, но хочу так сказать погрузиться.Тоесть вы хотите самостоятельно, повторно, анализировать план запроса который сгенерирует вам оптимизатор SQL сервера... Тут есть два момента - прочитать как работает оптимизаптор.. хотя бы в том же оракле... в мускуле он тоже примерно так же, по смыслу, но описание ораклового есть, а описание мускульного- незнаю, обычно посылают в исходники.. что как понимаете не одно и то же.. :) и подумать, сильно ли вы компетентнее программистов написавших оптимизатор... раз беретесь поправлять их... И второе - использование индексов оправдано только в некоторых случаях. Есть много случаев когда использование индекса делает запрос медленнее... сююююрпрааааайзззззз :))) Временная таблица на диске создается только если она нужна. Просто так она не создается. Проверьте... :) > Что у вас хочу спросить: Посоветуйте пожалуйста, как можно анализировать запрос, ну > т.е. к примеру всем проходящим через обёртку работы с БД запросам > SELECT перед их исполнением делать EXPLAIN и там анализировать то-то и > то-то, и в случае таких-то проблем сигнализировать, что данный запрос потенциально > "проблемный". Какие есть способы диагностики, может кроме EXPLAIN'а, с ним я > немного знаком. Может там на уровне самой БД что-то можно включить, > я смогу это связать со своим "конструктором".
можно. можно включить трейс работы оптимизатора и получить простыню на несколько гигабайт... но без багажа знаний хотябы на уровне DBA в крупной конторе, по-моему он будет не сильно полезен вам...
- Начиная с какого-то уровня сложности выборок нельзя просто так взять и сказать, , Аноним (2), 23:13 , 07-Апр-22 (2) +2
Начиная с какого-то уровня сложности выборок нельзя просто так взять и сказать, что запрос неоптимален. Вы хотите искусственный интеллект изобрести.
|