Maison > base de données > tutoriel mysql > Comment puis-je trier numériquement les lignes MySQL lorsque le champ de tri contient des données hybrides texte-numérique ?

Comment puis-je trier numériquement les lignes MySQL lorsque le champ de tri contient des données hybrides texte-numérique ?

Susan Sarandon
Libérer: 2024-12-29 03:14:10
original
860 Les gens l'ont consulté

How Can I Sort MySQL Rows Numerically When the Sort Field Contains Hybrid Text-Numeric Data?

Extraire des nombres à partir de champs hybrides texte-numérique dans MySQL

Le défi se pose lorsqu'il s'agit de colonnes contenant un mélange de texte et de valeurs numériques . Dans de tels cas, les méthodes de tri conventionnelles basées sur l'ordre des caractères peuvent entraîner un séquençage numérique incorrect.

Pour résoudre ce problème et trier en fonction des nombres intégrés, vous pouvez exploiter la requête MySQL suivante :

SELECT field,CONVERT(SUBSTRING_INDEX(field,'-',-1),UNSIGNED INTEGER) AS num
FROM table
ORDER BY num;
Copier après la connexion

Cette requête effectue les étapes suivantes :

  • SUBSTRING_INDEX() extrait le numéro du champ en le divisant au dernier trait d'union (-).
  • CONVERT() convertit le nombre extrait en un entier non signé, garantissant qu'il est traité comme une valeur numérique.
  • ORDER BY num trie les lignes en fonction des valeurs numériques extraites et converties champ.

En utilisant cette méthode, vous pouvez trier efficacement les lignes en fonction des nombres intégrés, quel que soit le texte précédent dans le champ. Notez que cela suppose que le numéro est toujours présent à la fin du champ, séparé par un trait d'union (-).

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