Maison > base de données > tutoriel mysql > Comment définir la différence de taille dans MySQL

Comment définir la différence de taille dans MySQL

PHPz
Libérer: 2023-04-19 17:30:06
original
6016 Les gens l'ont consulté

La base de données MySQL est un système de gestion de base de données relationnelle couramment utilisé pour stocker et accéder aux données dans les applications Web. Les tables de données dans MySQL ne sont pas sensibles à la casse, ce qui signifie qu'elles ne le sont pas lors de l'interrogation. Cependant, dans certains cas, MySQL doit être sensible à la casse, auquel cas les paramètres correspondants doivent être définis. Cet article explique comment définir la sensibilité à la casse dans MySQL.

1. Le principe de sensibilité à la casse dans MySQL

Dans MySQL, le nom est uniquement considéré comme un caractère, et non comme un mot ou une expression du langage. Par conséquent, MySQL n'utilise pas la casse pour déterminer la différence entre les noms. Par exemple, MySQL traite « table1 » et « Table1 » comme le même nom.

2. Définissez la sensibilité à la casse de MySQL

  1. Définissez-la dans le fichier de configuration my.cnf

Ouvrez le fichier de configuration my.cnf, s'il n'existe pas, créez un nouveau fichier. Ajoutez le code suivant au fichier :

[mysqld]
lower_case_table_names=1
Copier après la connexion

Enregistrez le fichier et redémarrez le serveur MySQL. Vous pouvez faire en sorte que MySQL applique le respect de la casse en définissant lower_case_table_names sur 1. S'il est défini sur 0, MySQL ne sera pas sensible à la casse et la valeur par défaut est 0.

  1. Défini dans la ligne de commande

Pour les utilisateurs qui n'ont pas l'autorisation de modifier le fichier de configuration MySQL, ils peuvent le définir dans la ligne de commande MySQL. Utilisez la commande suivante sur la ligne de commande :

SET GLOBAL lower_case_table_names=1;
Copier après la connexion

Cela définira le paramètre lower_case_table_names sur 1 globalement sur le serveur MySQL. Ce paramètre persistera lors des redémarrages du serveur MySQL.

Peut également être défini dans la session en cours en utilisant :

SET SESSION lower_case_table_names=1;
Copier après la connexion

Cela définira le paramètre lower_case_table_names sur 1 dans la session en cours. Ce paramètre expirera à la fin de la session en cours.

3. Notes

  1. L'utilisation du paramètre lower_case_table_names=1 entraînera la conversion de la casse des noms de table sensibles en minuscules. Si deux tables portent le même nom mais sont écrites dans des cas différents, elles deviennent la même table lorsque lower_case_table_names=1. Par conséquent, vous devez choisir soigneusement le nom de la table lorsque vous utilisez ce paramètre.
  2. Avec lower_case_table_names=1, les règles de tri ou de recherche non binaires sensibles à la casse, telles que utf8_bin, ne peuvent pas être utilisées. En effet, lower_case_table_names=1 convertira tous les caractères en minuscules, ce qui empêchera le tri sensible à la casse ou les règles de recherche de fonctionner.
  3. Avec lower_case_table_names=1, la fonctionnalité de jeu de caractères sensible à la casse n'est pas disponible. Par exemple, dans les jeux de caractères latin1_cs ou utf8_cs, cs indique le respect de la casse, mais lower_case_table_names=1 force tous les caractères à être convertis en minuscules, donc les règles de respect de la casse ne fonctionneront pas.

4. Résumé

Les paramètres par défaut de la base de données MySQL ne sont pas sensibles à la casse. Cependant, lorsque vous devez respecter la casse lors de l'interrogation, vous pouvez définir lower_case_table_names sur 1 dans le fichier de configuration my.cnf ou utiliser l'instruction SET dans la ligne de commande MySQL. Mais il convient de noter qu'il existe certaines restrictions sur l'utilisation de lower_case_table_names=1, ce qui peut causer des problèmes si le nom de la table ou le jeu de caractères n'est pas choisi avec soin. Il doit donc être utilisé avec prudence.

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!

source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal