Maison base de données tutoriel mysql 所用MySQL索引类型的应用与创建

所用MySQL索引类型的应用与创建

Jun 07, 2016 pm 04:09 PM
mysql principal 创建 应用 article 类型 索引

以下的文章主要描述的是MySQL索引类型,MySQL索引一共可以分为5中不同类型,以下的文章就是对正5种索引的具体应用以及实际创建方式的描述,希望会给你带来一些帮助在MySQL索引类型方面。 (1)MySQL索引类型:普通索引 这是最基本的索引,它没有任何限制。它有

以下的文章主要描述的是MySQL索引类型,MySQL索引一共可以分为5中不同类型,以下的文章就是对正5种索引的具体应用以及实际创建方式的描述,希望会给你带来一些帮助在MySQL索引类型方面。
 

(1)MySQL索引类型:普通索引

这是最基本的索引,它没有任何限制。它有以下几种创建方式:

创建索引

<ol class="dp-xml"><li class="alt"><span><span>CREATE INDEX indexName ON mytable(username(length)); </span></span></li></ol>
Copier après la connexion

如果是CHAR,VARCHAR类型,length可以小于字段实际长度;如果是BLOB和TEXT类型,必须指定 length,下同。

修改表结构

<ol class="dp-xml"><li class="alt"><span><span>ALTER mytable ADD INDEX [indexName] ON (username(length)) </span></span></li></ol>
Copier après la connexion

创建表的时候直接指定

<ol class="dp-xml"><li class="alt"><span><span>CREATE TABLE mytable( ID INT NOT NULL, username <br>VARCHAR(16) NOT NULL, INDEX [indexName] (username(length)) ); </span></span></li></ol>
Copier après la connexion

删除索引的语法:

<ol class="dp-xml"><li class="alt"><span><span>DROP INDEX [indexName] ON mytable; </span></span></li></ol>
Copier après la connexion

(2)MySQL索引类型:唯一索引

它与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。它有以下几种创建方式:

创建索引

<ol class="dp-xml"><li class="alt"><span><span>CREATE UNIQUE INDEX indexName ON mytable(username(length)) </span></span></li></ol>
Copier après la connexion

修改表结构

<ol class="dp-xml"><li class="alt"><span><span>ALTER mytable ADD UNIQUE [indexName] ON (username(length)) </span></span></li></ol>
Copier après la connexion

创建表的时候直接指定

<ol class="dp-xml"><li class="alt"><span><span>CREATE TABLE mytable( ID INT NOT NULL, <br>username VARCHAR(16) NOT NULL, UNIQUE [indexName] (username(length)) ); </span></span></li></ol>
Copier après la connexion

(3)MySQL索引类型:主键索引

它是一种特殊的唯一索引,不允许有空值。一般是在建表的时候同时创建主键索引:

<ol class="dp-xml"><li class="alt"><span><span>CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, PRIMARY KEY(ID) ); </span></span></li></ol>
Copier après la connexion

当然也可以用 ALTER 命令。记住:一个表只能有一个主键。

(4)MySQL索引类型:组合索引

为了形象地对比单列索引和组合索引,为表添加多个字段:

<ol class="dp-xml"><li class="alt"><span><span>CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, <br>city VARCHAR(50) NOT NULL, age INT NOT NULL ); </span></span></li></ol>
Copier après la connexion

为了进一步榨取MySQL的效率,就要考虑建立组合索引。就是将 name, city, age建到一个索引里:

<ol class="dp-xml"><li class="alt"><span><span>ALTER TABLE mytable ADD INDEX name_city_age (name(10),city,age); </span></span></li></ol>
Copier après la connexion

建表时,usernname长度为 16,这里用 10。这是因为一般情况下名字的长度不会超过10,这样会加速索引查询速度,还会减少索引文件的大小,提高INSERT的更新速度。

如果分别在 usernname,city,age上建立单列索引,让该表有3个单列索引,查询时和上述的组合索引效率也会大不一样,远远低于我们的组合索引。虽然此时有了三个索引,但MySQL只能用到其中的那个它认为似乎是最有效率的单列索引。

建立这样的组合索引,其实是相当于分别建立了下面三组组合索引:

<ol class="dp-xml"><li class="alt"><span><span>usernname,city,age usernname,city usernname </span></span></li></ol>
Copier après la connexion

为什么没有 city,age这样的组合索引呢?

这是因为MySQL组合索引“最左前缀”的结果。简单的理解就是只从最左面的开始组合。并不是只要包含这三列的查询都会用到该组合索引,下面的几个SQL就会用到这个组合索引:

<ol class="dp-xml"><li class="alt"><span><span>SELECT * FROM mytable WHREE </span><span class="attribute">username</span><span>=</span><span class="attribute-value">"admin"</span><span> AND </span><span class="attribute">city</span><span>=</span><span class="attribute-value">"郑州"</span><span> <br>SELECT * FROM mytable WHREE </span><span class="attribute">username</span><span>=</span><span class="attribute-value">"admin"</span><span> </span></span></li></ol>
Copier après la connexion

而下面几个则不会用到:

<ol class="dp-xml"><li class="alt"><span><span>SELECT * FROM mytable WHREE </span><span class="attribute">age</span><span>=</span><span class="attribute-value">20</span><span> AND </span><span class="attribute">city</span><span>=</span><span class="attribute-value">"郑州"</span><span> <br>SELECT * FROM mytable WHREE </span><span class="attribute">city</span><span>=</span><span class="attribute-value">"郑州"</span><span> </span></span></li></ol>
Copier après la connexion

(5)MySQL索引类型:建立索引的时机

到这里我们已经学会了建立索引,那么我们需要在什么情况下建立索引呢?一般来说,在WHERE和JOIN中出现的列需要建立索引,但也不完全如此,因为MySQL只对,>=,BETWEEN,IN,以及某些时候的LIKE才会使用索引。例如:

<ol class="dp-xml"><li class="alt"><span><span>SELECT t.Name FROM mytable t LEFT JOIN mytable m ON </span><span class="attribute">t.<br>Name</span><span>=m.username WHERE </span><span class="attribute">m.age</span><span>=</span><span class="attribute-value">20</span><span> AND </span><span class="attribute">m.city</span><span>=</span><span class="attribute-value">'郑州'</span><span> </span></span></li></ol>
Copier après la connexion

此时就需要对city和age建立索引,由于mytable表的userame也出现在了JOIN子句中,也有对它建立索引的必要。

刚才提到只有某些时候的LIKE才需建立索引。因为在以通配符%和_开头作查询时,MySQL不会使用索引。例如下句会使用索引:

<ol class="dp-xml"><li class="alt"><span><span>SELECT * FROM mytable WHERE username like'admin%' </span></span></li></ol>
Copier après la connexion

而下句就不会使用:

<ol class="dp-xml"><li class="alt"><span><span>SELECT * FROM mytable WHEREt Name like'%admin' </span></span></li></ol>
Copier après la connexion

以上的相关内容就是对MySQL索引类型的介绍,望你能有所收获。
 


Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser la sauvegarde et la restauration MySQL en PHP ? Comment utiliser la sauvegarde et la restauration MySQL en PHP ? Jun 03, 2024 pm 12:19 PM

La sauvegarde et la restauration d'une base de données MySQL en PHP peuvent être réalisées en suivant ces étapes : Sauvegarder la base de données : Utilisez la commande mysqldump pour vider la base de données dans un fichier SQL. Restaurer la base de données : utilisez la commande mysql pour restaurer la base de données à partir de fichiers SQL.

Comment optimiser les performances des requêtes MySQL en PHP ? Comment optimiser les performances des requêtes MySQL en PHP ? Jun 03, 2024 pm 08:11 PM

Les performances des requêtes MySQL peuvent être optimisées en créant des index qui réduisent le temps de recherche d'une complexité linéaire à une complexité logarithmique. Utilisez PreparedStatements pour empêcher l’injection SQL et améliorer les performances des requêtes. Limitez les résultats des requêtes et réduisez la quantité de données traitées par le serveur. Optimisez les requêtes de jointure, notamment en utilisant des types de jointure appropriés, en créant des index et en envisageant l'utilisation de sous-requêtes. Analyser les requêtes pour identifier les goulots d'étranglement ; utiliser la mise en cache pour réduire la charge de la base de données ; optimiser le code PHP afin de minimiser les frais généraux.

Comment insérer des données dans une table MySQL en utilisant PHP ? Comment insérer des données dans une table MySQL en utilisant PHP ? Jun 02, 2024 pm 02:26 PM

Comment insérer des données dans une table MySQL ? Connectez-vous à la base de données : utilisez mysqli pour établir une connexion à la base de données. Préparez la requête SQL : Écrivez une instruction INSERT pour spécifier les colonnes et les valeurs à insérer. Exécuter la requête : utilisez la méthode query() pour exécuter la requête d'insertion en cas de succès, un message de confirmation sera généré.

Comment utiliser les procédures stockées MySQL en PHP ? Comment utiliser les procédures stockées MySQL en PHP ? Jun 02, 2024 pm 02:13 PM

Pour utiliser les procédures stockées MySQL en PHP : Utilisez PDO ou l'extension MySQLi pour vous connecter à une base de données MySQL. Préparez l'instruction pour appeler la procédure stockée. Exécutez la procédure stockée. Traitez le jeu de résultats (si la procédure stockée renvoie des résultats). Fermez la connexion à la base de données.

Comment créer une table MySQL en utilisant PHP ? Comment créer une table MySQL en utilisant PHP ? Jun 04, 2024 pm 01:57 PM

La création d'une table MySQL à l'aide de PHP nécessite les étapes suivantes : Connectez-vous à la base de données. Créez la base de données si elle n'existe pas. Sélectionnez une base de données. Créer un tableau. Exécutez la requête. Fermez la connexion.

Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Dec 09, 2024 am 11:42 AM

L'un des changements majeurs introduits dans MySQL 8.4 (la dernière version LTS en 2024) est que le plugin « MySQL Native Password » n'est plus activé par défaut. De plus, MySQL 9.0 supprime complètement ce plugin. Ce changement affecte PHP et d'autres applications

La différence entre la base de données Oracle et MySQL La différence entre la base de données Oracle et MySQL May 10, 2024 am 01:54 AM

La base de données Oracle et MySQL sont toutes deux des bases de données basées sur le modèle relationnel, mais Oracle est supérieur en termes de compatibilité, d'évolutivité, de types de données et de sécurité ; tandis que MySQL se concentre sur la vitesse et la flexibilité et est plus adapté aux ensembles de données de petite et moyenne taille. ① Oracle propose une large gamme de types de données, ② fournit des fonctionnalités de sécurité avancées, ③ convient aux applications de niveau entreprise ; ① MySQL prend en charge les types de données NoSQL, ② a moins de mesures de sécurité et ③ convient aux applications de petite et moyenne taille.

Comment supprimer des données d'une table MySQL en utilisant PHP ? Comment supprimer des données d'une table MySQL en utilisant PHP ? Jun 05, 2024 pm 12:40 PM

PHP fournit les méthodes suivantes pour supprimer des données dans les tables MySQL : Instruction DELETE : utilisée pour supprimer les lignes correspondant aux conditions de la table. Instruction TRUNCATETABLE : utilisée pour effacer toutes les données de la table, y compris les ID auto-incrémentés. Cas pratique : Vous pouvez supprimer des utilisateurs de la base de données à l'aide de formulaires HTML et de code PHP. Le formulaire soumet l'ID utilisateur et le code PHP utilise l'instruction DELETE pour supprimer l'enregistrement correspondant à l'ID de la table des utilisateurs.

See all articles