Maison >base de données >Oracle >Comment Oracle rend-il l'index invalide ?
Causes de l'échec de l'index Oracle : 1. Ne pas utiliser la clause WHERE ; 2. Utiliser "IS NULL" et "IS NOT NULL" ; 3. Utiliser les fonctions dans la clause WHERE ; 4. Utiliser LIKE pour une requête floue ; opération d'inégalité dans la clause WHERE ; 6. Comparez les types de données sans correspondance, etc.
L'environnement d'exploitation de ce tutoriel : système Windows 10, version Oracle 11g, ordinateur Dell G3.
L'objectif des index Oracle est d'éviter les analyses de tables complètes et d'améliorer l'efficacité des requêtes, mais cela est parfois contre-productif.
Par exemple, s'il y a des millions de données dans une table et qu'un index est ajouté à un certain champ, mais que les performances de la requête ne s'améliorent pas, cela peut être dû à l'échec de l'index Oracle. Les index Oracle ont certaines restrictions. Si vous violez ces restrictions d'index, même si vous avez ajouté un index, Oracle effectuera toujours une analyse complète de la table. Les performances des requêtes ne seront pas améliorées par rapport à l'absence d'index. à la base de données La surcharge du système liée à la maintenance de l'index entraîne une dégradation des performances. Ce qui suit est un résumé des sept contraintes pouvant entraîner l'échec des index Oracle.
1. Pas de clause WHERE
2. Utilisez IS NULL et IS NOT NULL
SELECT ... FROM emp WHERE comm IS NULL ; L'index de la colonne comm sera invalide
3. Utilisation de fonctions dans
Si vous n'utilisez pas d'index basés sur des fonctions, l'utilisation de fonctions sur des colonnes indexées dans la clause Where entraînera l'optimisation de ces index par l'optimiseur. Par exemple :
select * from staff where trunc(birthdate) = '01-MAY-82';
Mais lorsque la fonction est appliquée à la condition, l'index peut prendre effet. Remplacez l'instruction ci-dessus par l'instruction suivante et vous pouvez effectuer une recherche dans l'index.
select * from staff where birthdate < (to_date('01-MAY-82') + 0.9999);
Remarque : Oracle utilise toujours des index pour les fonctions MIN, MAX.
4. Utilisez LIKE '%T' pour une requête floue
5. Utilisez l'opération d'inégalité dans la clause WHERE
L'opération d'inégalité comprend : a8093152e673feb7aba1828c43532094, !=, NOT colum >= ? , NOT colum <= ?
Cette restriction peut être remplacée par OR, par exemple : colum a8093152e673feb7aba1828c43532094 0 ===> colum>0 OR colum<0
6. Fusionner à l'aide de
SELECT emp_id, emp_m, salary_q ... FROM emp WHERE job='manager' AND deptno>10
job et deptno sont tous deux des index non uniques. Dans cette condition, Oracle ne fusionnera pas les index, il n'utilisera que le premier index.
7. Comparaison de types de données sans correspondance
dept_id est un champ varchar2 Il y a un index sur ce champ, mais l'instruction suivante effectuera une analyse complète de la table.
select * from dept where dept_id = 900198;
En effet, Oracle convertira automatiquement la clause Where en to_number(dept_id)=900198, ce qui équivaut à utiliser une fonction, qui limite l'utilisation des index. La bonne façon de l'écrire est la suivante :
select * from dept where dept_id = '900198';
Tutoriel recommandé : "Tutoriel vidéo Oracle"
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!