承接 tourze/doctrine-use-index-walker 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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

English | 中文

Latest Version PHP Version License Build Status Quality Score Coverage Status Total Downloads

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 INDEX or FORCE INDEX hints 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 INDEX and FORCE INDEX are set, USE INDEX takes 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:

  1. If UseIndexWalker::HINT_USE_INDEX is set, adds USE INDEX (index_name) to the FROM clause
  2. If UseIndexWalker::HINT_FORCE_INDEX is set, adds FORCE 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

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-04-25