Download the PHP package shipmonk/doctrine-mysql-optimizer-hints without Composer
On this page you can find all versions of the php package shipmonk/doctrine-mysql-optimizer-hints. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download shipmonk/doctrine-mysql-optimizer-hints
More information about shipmonk/doctrine-mysql-optimizer-hints
Files in shipmonk/doctrine-mysql-optimizer-hints
Package doctrine-mysql-optimizer-hints
Short Description Custom SQL walker for Doctrine allowing usage of MySQL optimizer hints without need of native queries
License MIT
Informations about the package doctrine-mysql-optimizer-hints
MySQL optimizer hints for Doctrine
This library provides a simple way to incorporate MySQL's optimizer hints into SELECT queries written in Doctrine Query Language via custom SqlWalker. No need for native queries anymore.
Installation:
Example usage:
Which produces following SQL:
Be careful what you place as optimizer hint, you are basically writing SQL there, but MySQL produces only warnings when a typo is made there.
Use cases:
Limiting / extending max execution time for a single query:
Any reasonable application uses some global max_execution_time to avoid queries running for hours.
But you may want to break this limitation for a single long-running query.
Doing so by SET max_execution_time = 10000;
is tricky as you should revert that to previous value just after the query ends.
This results in complex code around it, optimizer hint does that for you for free:
Query optimization:
Sometimes, forcing some index usage is not enough and you need to help MySQL optimizer to adjust the order of tables in execution plan.
Join-order optimizer hints are the way to go.
Simpliest usage is to force the table order to be exactly as you wrote it is using JOIN_FIXED_ORDER()
:
Testing invisible index:
When dealing with complex query optimization on production, you can only guess if the new index you thought up will help or not. Since MySQL 8.0, you can create invisible index (those are maintained by the engine, but not used). But you can enable invisible indexes for the query you want to test:
Enlarging group_concat limit for a single query
Default limit of group_concat_max_len is 1024, but you can make it bigger:
Combining with index hints:
Since 2.0.0, you can combine this library with shipmonk/doctrine-mysql-index-hint: