Maison >base de données >tutoriel mysql >configuration du jeu de caractères mysql5.7.18
Contexte de l'histoire :
Il y a longtemps (2017.6.5, l'article a son actualité, surtout les outils utilisés sont mis à jour fréquemment, n'oubliez pas cette fois, si vous y avez n'a aucune valeur, tout est soumis à la documentation officielle de l'outil). J'ai téléchargé une version de MySQL pour jouer. La dernière version se trouve être mysql5.7.18. Cette machine est un système Win10, 64 bits. Les étapes sont grossièrement divisées en :
1. Téléchargement : reportez-vous au site officiel (), le téléchargement répond à la version du système
2. Initialisation : ligne de commande (cmd) pour saisir le dossier bin du répertoire de décompression (télécharger Vous devriez le décompresser après l'avoir téléchargé, n'est-ce pas ? Cela a pris trop de temps et je l'ai oublié. De plus, il n'y a pas de dossier de données ni de fichiers ini lors du téléchargement. Il existe deux méthodes d'initialisation). L'une est appelée initialisation non sécurisée, et saisissez : mysqld --initialize, l'initialisation laisse l'utilisateur root sans mot de passe (pas de mot de passe, donc ce n'est pas sûr), l'autre est ce qu'on appelle l'initialisation sécurisée, saisissez : mysqld --initialize ; -insecure, et génère un mot de passe L'utilisateur root, le mot de passe peut être consulté dans le fichier journal qui apparaît après génération, dans le fichier de données généré après initialisation
3. Démarrez le service : Entrez : net start mysql (fermez le service : Entrée : net stop mysql), s'il indique que net n'est pas une commande interne, alors il se peut que net ne soit pas installé, ou que les variables d'environnement ne soient pas configurées, cochez simplement
4. En gros, cela devrait être comme ça, d'autres peuvent le faire. Consultez la liste des commandes mysql pour le faire.
Ensuite, parlons du problème de la configuration du jeu de caractères.
Cause :
Hier encore, c'était trop abstrait pour afficher les données sur la ligne de commande mysql, j'ai donc d'abord téléchargé Navicat pour mysql (interface visuelle), et ça avait l'air bien mieux. Comme le montre l'image :
Ensuite, lors de l'insertion de données dans le tableau, une erreur "Valeur de chaîne incorrecte" sera signalée et indiquera qu'il doit modifier le jeu de caractères. à utf8mb4. C'est parce que d'autres L'encodage ne peut pas stocker certains caractères spéciaux. Veuillez vous référer à Baidu pour plus de détails.
Après :
Pour modifier le jeu de caractères, entrez d'abord mysql : mysql -uroot (login de l'utilisateur, car celui sans mot de passe a été sélectionné pour l'initialisation), affichez des variables comme 'char%' ( vérifiez l'encodage des caractères ), comme indiqué sur la figure :
Vous pouvez saisir dans la ligne de commande par exemple : set Character_set_server=utf8mb4 pour modifier le jeu de caractères, mais c'est valable uniquement pour cette période et sera restauré à la valeur par défaut au redémarrage du service. Ensuite, essayez d’autres méthodes. Il existe différentes opinions sur Internet, et elles sont si vagues qu’il est difficile de distinguer le vrai du faux. Alors je suis allé sur le site officiel et j'ai jeté un œil (le site officiel est aussi très déroutant, il n'y a pas d'exemples auxquels se référer, c'est comme dire à un aveugle que le blanc est blanc, et je suis cet aveugle), et j'ai vu qu'il existe une commande pour afficher les variables dans le document : mysqld --verbose -- help, les variables affichées peuvent être configurées dans le fichier d'options, à chaque démarrage du service, il sera automatiquement configuré en fonction du fichier d'options, et alors une phrase apparaîtra ici :
Les options par défaut sont lues à partir des fichiers suivants dans l'ordre donné
Je pense que cela devrait être là où le fichier d'options peut exister, ce qui signifie que le nouveau fichier d'options que nous créons doit être nommé d'après le nom qu'il affiche et placé là où il doit être placé. Comme le montre l'image :
Créez un nouveau fichier my.ini et placez-le sous D: mysql, qui se trouve être l'un des emplacements qu'il affiche, comme indiqué ci-dessus . Le contenu de my.ini est le suivant :
Il est essentiellement configuré sous cette forme. Ici, nous prenons uniquement le coupable Character_set_server. Bien entendu, la configuration du jeu de caractères associé doit être effectuée. être unifié, sinon il peut être tronqué. Vous pouvez aller sur Baidu pour voir ce que signifie chaque jeu de caractères.
Fermez ensuite le service mysql et démarrez la configuration (entrez mysqld --install) :
1. Si un non-administrateur ouvre cmd et entre mysqld --install, le message suivant sera signalé , disant que la commande est rejetée. :
2. Ouvrez-le avec l'administrateur, et il indique que le service existe déjà (puis supprimez-le d'abord) :
3. Interroger le service mysql : sc query mysql (peut également être trouvé dans Panneau de configuration-Outils d'administration-Services, ou rechercher directement des services)
4 , Supprimez-le : (Vous pouvez également le désinstaller dans Panneau de configuration-Outils d'administration-Services, ou rechercher directement des services)
5. bien sûr, vous devez arrêter mysql avant de le réinstaller, même si supprimez-le d'abord, sinon il apparaîtra :
6. Nous l'avons arrêté. Cette fois, nous l'avons arrêté dans le panneau de configuration car nous l'avions déjà désinstallé et il a disparu après l'avoir arrêté (ligne de commande : net stop mysql). Nous l'avons réexécuté et avons démarré le service mysql avec succès. :
7. Redémarrez avec succès, montez et voyez s'il y a des changements avec succès :
8. Puis C'est tout. Je l'ai essayé quelques fois plus tard. Tant que je modifiais mon.ini, fermais et redémarrais le service mysql, cela changerait mon.ini à chaque fois. si vous n'êtes pas satisfait, modifiez simplement my.ini et redémarrez le service. Comme le montre l'image :
Je vais encore le changer :
Voilà pour la configuration, bye !
>
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!