Maison > base de données > tutoriel mysql > Comment trouver la correspondance numérique la plus proche dans une base de données à l'aide de SQL ?

Comment trouver la correspondance numérique la plus proche dans une base de données à l'aide de SQL ?

Mary-Kate Olsen
Libérer: 2025-01-03 21:40:40
original
724 Les gens l'ont consulté

How to Find the Closest Numeric Match in a Database Using SQL?

Trouver la valeur numérique la plus proche dans une base de données

Cette discussion se concentre sur l'extraction d'un enregistrement spécifique d'une base de données qui correspond étroitement à une entrée donnée. Si une correspondance exacte n'existe pas, la requête doit renvoyer la correspondance la plus proche basée sur un champ numérique.

L'instruction SQL fournie vise à récupérer les données de la table "myTable", en filtrant les résultats en fonction de valeurs spécifiques pour le Colonnes "Nom", "Taille" et "PType". Pour s'adapter au scénario de recherche de la correspondance la plus proche pour le champ « Zone », des ajustements de l'instruction sont nécessaires.

Pour y parvenir, l'exemple démontre l'utilisation de la fonction « ABS ». En encapsulant la soustraction de la colonne « Zone » de la valeur d'entrée dans la fonction « ABS », le résultat est toujours positif, garantissant que l'étape de commande suivante identifie avec précision la correspondance la plus proche.

La requête modifiée ci-dessous suit ce concept, en ordonnant les résultats par différence absolue entre la colonne "Zone" et l'entrée :

SELECT TOP 1 * FROM [myTable] 
WHERE Name = 'Test' and Size = 2 and PType = 'p'
ORDER BY ABS( Area - @input ) 
Copier après la connexion

En incorporant cette modification, la requête renverra l'enregistrement avec un Valeur « Zone » qui correspond le plus à la valeur d'entrée, résolvant efficacement le besoin de trouver la correspondance numérique la plus proche dans la base de données.

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