Maison > développement back-end > Problème PHP > Comment résoudre les caractères chinois tronqués dans la base de données affichée par PHP

Comment résoudre les caractères chinois tronqués dans la base de données affichée par PHP

PHPz
Libérer: 2023-04-21 09:32:14
original
976 Les gens l'ont consulté

Lorsque nous utilisons PHP pour appeler la base de données pendant le développement, nous rencontrons souvent le problème des caractères chinois tronqués. Ce problème est généralement dû au fait que le jeu de caractères de la base de données est différent du jeu de caractères PHP ou que PHP n'analyse pas correctement les caractères chinois dans la base de données. Dans cet article, nous expliquerons comment résoudre le problème des caractères chinois tronqués en PHP.

1. Configurer le jeu de caractères de la base de données

1.1 Afficher le jeu de caractères de la base de données
Entrez la commande suivante sur l'interface de ligne de commande pour afficher le jeu de caractères actuel de la base de données :

show variables like 'character%';
Copier après la connexion

1.2 Définir le jeu de caractères de la base de données
Afin de Pour résoudre le problème des caractères chinois tronqués, le jeu de caractères de la base de données doit être modifié en utf8. Dans MySQL, vous pouvez le définir avec la commande suivante :

ALTER DATABASE `database_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
Copier après la connexion

où, database_name est le nom de la base de données que vous souhaitez définir. Ici, le jeu de caractères par défaut de la base de données est défini sur utf8. Dans MySQL, utf8 est le jeu de caractères le plus couramment utilisé et peut prendre en charge les caractères dans la plupart des langues. database_name是你要设置的数据库名称。这里将数据库的默认字符集设置为utf8。在mysql中,utf8是最常用的字符集,能够支持绝大多数语言的字符。

1.3 设置数据表字符集
在mysql中,每个数据表也可以单独设置字符集。通过以下命令可以将某个表的字符集设置为utf8:

ALTER TABLE `table_name` CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;
Copier après la connexion

其中,table_name

1.3 Définir le jeu de caractères de la table de données

Dans MySQL, chaque table de données peut également définir le jeu de caractères indépendamment. Vous pouvez définir le jeu de caractères d'une table sur utf8 via la commande suivante :

mbstring.language=CN
Copier après la connexion

Où, table_name est le nom de la table de données que vous souhaitez définir. Ici, le jeu de caractères de la table de données est défini sur utf8. De cette façon, toutes les tables de la base de données utiliseront le jeu de caractères utf8.

2. Définir le jeu de caractères PHP


2.1 Définir le jeu de caractères PHP par défaut

Ouvrez le fichier php.ini, puis recherchez le paramètre "mbstring.langue" et définissez sa valeur sur "CN". Comme indiqué ci-dessous :

header('content-type:text/html;charset=utf-8');
Copier après la connexion
2.2 Définir le jeu de caractères d'exécution PHP

En PHP, vous devez également définir le jeu de caractères d'exécution. Vous pouvez définir le jeu de caractères de php via le code suivant :

$conn = mysql_connect($dbhost, $dbuser, $dbpass) or die('连接数据库失败!');
mysql_select_db($dbname, $conn);
mysql_query("SET NAMES 'utf8'");
Copier après la connexion

Ce code définira le jeu de caractères de sortie de php sur utf-8.

3. Appeler les caractères chinois dans la base de données

3.1 Jeu de caractères de lien de base de données

En php, vous devez définir le jeu de caractères lors de la liaison à la base de données :

mysql_query("set character_set_client=utf8");
mysql_query("set character_set_results=utf8");
Copier après la connexion
Parmi eux, $dbhost, $. dbuser, $dbpass, $dbname sont respectivement l'adresse de l'hôte, l'utilisateur, le mot de passe et le nom de la base de données. Ici, nous définissons le jeu de caractères de la base de données sur utf8 via la fonction mysql_query().
  1. 3.2 Définir le jeu de caractères de la requête
    S'il y a des caractères chinois dans la requête, vous devez définir le jeu de caractères de la requête. Vous pouvez définir le jeu de caractères de requête via le code suivant :
  2. $result = mysql_query("SELECT * FROM table_name");
    while($row = mysql_fetch_array($result)){
        echo $row['field_name'];
    }
    Copier après la connexion

Résultats des tests

Après avoir configuré le jeu de caractères de la base de données et le jeu de caractères php, nous pouvons tester le chinois dans la base de données. Vous pouvez créer un tableau et y insérer un caractère chinois, puis le visualiser avec le code suivant :

rrreee

De cette façon, les caractères chinois peuvent s'afficher correctement sur la page.

🎜5. Résumé🎜🎜Grâce aux étapes ci-dessus, nous pouvons résoudre le problème des caractères chinois tronqués dans la base de données d'affichage PHP. Afin d'afficher correctement les caractères chinois, vous devez définir à la fois le jeu de caractères de la base de données et le jeu de caractères PHP sur utf8, et définir correctement le jeu de caractères de requête et le jeu de caractères de lien. De cette façon, les caractères chinois peuvent être utilisés dans le développement et affichés correctement. 🎜

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