MySQL est un système de gestion de bases de données relationnelles open source largement utilisé dans le stockage de données et la gestion de diverses applications. Dans la tendance actuelle à l'internationalisation, la prise en charge multilingue est devenue une fonctionnalité indispensable pour de nombreuses applications. Cependant, MySQL ne fournit pas directement de fonctionnalités multilingues, les développeurs doivent donc suivre quelques astuces pour implémenter la prise en charge multilingue.
Cet article présentera quelques conseils de prise en charge multilingue dans MySQL, visant à aider les développeurs à implémenter plus facilement les fonctions de prise en charge multilingue.
Dans MySQL, la pratique courante consiste à ajouter un préfixe de code de langue à chaque champ multilingue. Par exemple, il existe un champ « nom » qui contient plusieurs versions linguistiques du nom. Vous pouvez ajouter des préfixes aux noms de différentes versions linguistiques, tels que « en_name » pour les noms anglais et « zh_name » pour les noms chinois.
L'avantage de cette méthode est qu'il est facile de sélectionner la langue dans le code, et qu'elle est également pratique pour maintenir et gérer des données multilingues.
Une autre façon courante d'implémenter des fonctionnalités multilingues consiste à utiliser la prise en charge multilingue des tables de base de données. L'avantage de cette approche est que les données multilingues peuvent être facilement organisées ensemble, plutôt que de stocker les champs pour chaque langue séparément.
Pour implémenter la prise en charge multilingue des tables de base de données, deux tables doivent être créées. La première table est utilisée pour stocker l'ID de clé primaire et les champs publics de toutes les versions linguistiques, tels que l'horodatage, le créateur, le titre et le contenu, etc. Le deuxième tableau contient les champs de texte et les codes de langue pour chaque version linguistique.
En utilisant une requête JOIN, vous pouvez faire correspondre les champs multilingues de la première table avec les codes de langue de la deuxième table pour faciliter la recherche et l'affichage de versions linguistiques spécifiques dans votre application.
Stocker du texte multilingue sous forme de chaîne unique est une autre façon d'implémenter des fonctionnalités multilingues. Cette méthode relie différentes versions linguistiques du texte, les sépare avec un délimiteur, puis les stocke dans un seul champ.
Cette approche nécessite de bonnes stratégies de délimiteur et des conventions de code de langue pour garantir que le texte peut être analysé et affiché correctement lorsqu'il est affiché.
Pour MySQL 5.7 et supérieur, vous pouvez utiliser le format JSON pour stocker du contenu multilingue. L’avantage de cette méthode est qu’elle prend en charge des structures imbriquées complexes, qu’elle est facile à utiliser et qu’elle est facile à maintenir et à mettre à jour.
Lorsque vous utilisez le format JSON pour stocker du texte multilingue, un champ JSON est requis pour stocker le contenu du texte et le code de langue. Par exemple :
{
"en": "Hello, world!",
"zh": "Hello, world!"
}
Si nécessaire, vous pouvez utiliser la fonction JSON de MySQL pour extraire une langue spécifique d'un JSON. contenu du champ.
Résumé
MySQL ne prend pas directement en charge les fonctionnalités multilingues, mais les développeurs peuvent utiliser les techniques ci-dessus pour obtenir une prise en charge multilingue. Chaque méthode a ses avantages et ses inconvénients, et c'est au développeur de peser le pour et le contre et de choisir celle qui convient le mieux à l'application.
L'utilisation d'une version de support à long terme (LTS) de MySQL garantit des performances plus efficaces et une meilleure stabilité lors de l'utilisation de ces conseils.
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!