tourze/doctrine-use-index-walker
最新稳定版本:0.1.0
Composer 安装命令:
composer require tourze/doctrine-use-index-walker
包简介
Auto add USE INDEX in doctrine query
README 文档
README
A Doctrine ORM SQL Walker for automatically adding USE INDEX or FORCE INDEX hints to MySQL queries, helping you optimize SQL performance with minimal code changes.
Features
- Automatically injects
USE INDEXorFORCE INDEXhints into Doctrine queries - Works only on MySQL platforms, compatible with Doctrine ORM 3.0+
- Simple usage via query hints
- Fully compatible with native Doctrine query API
Installation
Install via Composer:
composer require tourze/doctrine-use-index-walker
Requirements:
- PHP 8.2 or higher
- Doctrine ORM 3.0+
- Doctrine DBAL 4.0+
Quick Start
<?php use Tourze\DoctrineUseIndexWalker\UseIndexWalker; use Doctrine\ORM\Query; // Create a query $query = $entityManager->createQuery('SELECT u FROM User u WHERE u.name = :name'); $query->setParameter('name', 'john'); // Add USE INDEX hint $query->setHint(Query::HINT_CUSTOM_TREE_WALKERS, [UseIndexWalker::class]); $query->setHint(UseIndexWalker::HINT_USE_INDEX, 'idx_user_name'); // Or add FORCE INDEX hint $query->setHint(Query::HINT_CUSTOM_TREE_WALKERS, [UseIndexWalker::class]); $query->setHint(UseIndexWalker::HINT_FORCE_INDEX, 'idx_user_name'); // Execute query $result = $query->getResult();
Notes
- Only works on MySQL database platforms
- If both
USE INDEXandFORCE INDEXare set,USE INDEXtakes precedence - Index hint syntax depends on your MySQL version; refer to the MySQL documentation for details
How It Works
When the walker is applied to a query, it checks if the platform is MySQL and modifies the SQL accordingly:
- If
UseIndexWalker::HINT_USE_INDEXis set, addsUSE INDEX (index_name)to the FROM clause - If
UseIndexWalker::HINT_FORCE_INDEXis set, addsFORCE INDEX (index_name)to the FROM clause
Contributing
Feel free to open issues or pull requests. Please follow PSR coding standards and include tests where possible.
License
MIT License
统计信息
- 总下载量: 3
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-04-25