[SQL] Trié par adresse IP

Résolu
afrodje Messages postés 759 Date d'inscription   Statut Membre Dernière intervention   -  
Schiver Messages postés 20 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour,

Je ne trouve pas comment trier dans un orde croissant un champ qui contient des adresses IP:

par exemple actuellement :

192.168.1.1
192.168.1.100
192.168.1.122
192.168.1.20
192.168.1.251
192.168.1.30



Alors que je voudrais avoir :

192.168.1.1
192.168.1.20
192.168.1.30
192.168.1.100
192.168.1.122
192.168.1.251


Merci

A voir également:

5 réponses

afrodje Messages postés 759 Date d'inscription   Statut Membre Dernière intervention   168
 
Voila la solution :


SELECT 
CONVERT(SUBSTRING_INDEX(adresse_ip, '.', 1), UNSIGNED INTEGER) as nb1,
CONVERT(SUBSTRING_INDEX(SUBSTRING_INDEX(adresse_ip, '.', 2), '.', -1), UNSIGNED INTEGER) as nb2,
CONVERT(SUBSTRING_INDEX(SUBSTRING_INDEX(adresse_ip, '.', -2), '.', 1), UNSIGNED INTEGER) as nb3,
CONVERT(SUBSTRING_INDEX(SUBSTRING_INDEX(adresse_ip, '.', -2), '.', -1), UNSIGNED INTEGER) as nb4,
adresse_ip
from table1
ORDER BY nb1,nb2,nb3,nb4 

2
Schiver Messages postés 20 Date d'inscription   Statut Membre Dernière intervention  
 
Il y a beaucoup plus simple. J'ai trouvé sur un site qu'une solution en deux lignes existe... Je l'ai testé pour vérifié mais tout fonctionne parfaitement...


mysql> SELECT INET_ATON(adresseIP)AS bin_ip, adresseIP
-> FROM plageadresseip
-> ORDER BY bin_ip;

qui donnera le résultat suivant :

+------------------+---------------+
| bin_ip | adresseIP |
+------------------+---------------+
| 1124767601 | 67.10.151.113 |
| 1146676993 | 68.88.231.1 |
| 1146676994 | 68.88.231.2 |
| 1146676995 | 68.88.231.3 |
| 1146677002 | 68.88.231.10 |
| 1146677014 | 68.88.231.22 |
| 1146677015 | 68.88.231.23 |
| 1146677016 | 68.88.231.24 |
| 1146677017 | 68.88.231.25 |
| 1146677018 | 68.88.231.26 |
| 1146677019 | 68.88.231.27 |
| 1146677020 | 68.88.231.28 |
| 1146677021 | 68.88.231.29 |
| 1146677022 | 68.88.231.30 |
+------------+---------------+

Pour ne pas afficher la colonne bin_ip, il faut juste appliquer la requête de cette manière :

SELECT adresseIP
FROM plageadresseip
ORDER BY INET_ATON( adresseIP );


La fonction INET_ATON (ATON = Adresse TO Number) est très efficace...
Une autre fonction existe qui permet de faire le processus inverse... elle s'appelle très logiquement INET_NTOA... ;-)
0
toto
 
Bonjour

Tu es obligé de décomposer l'adresse en 4 champs numériques. Le détail de la syntaxe dépend totalement du langage que tu utilises pour faire ce tri.
Bien sûr, si tu travailles toujours sur le sous-réseau 192.168.1.x, extraire le dernier champ peut suffire.
0
afrodje Messages postés 759 Date d'inscription   Statut Membre Dernière intervention   168
 
Le faire en PHP, y a pas de prob, mais je dois le faire en sql...
0
toto > afrodje Messages postés 759 Date d'inscription   Statut Membre Dernière intervention  
 
En mysql, il y a la fonction SUBSTRING_INDEX(str,delim,count) qui permettrait d'extraire les 4 parties de l'adresse (laborieusement, mais ça doit être faisable. Il y a peut-être un équivalent SQL ?
0
Nuk Messages postés 177 Date d'inscription   Statut Membre Dernière intervention   20
 
Bonsoir,

Essaye un truc du genre


Select * from monchamp order by monchamp ASC;

A moins que je me fourvoie completement et que je t'ai pris pour un debutant...
Si c'est le cas je m'en excuse.
0
afrodje Messages postés 759 Date d'inscription   Statut Membre Dernière intervention   168
 
C'est le cas ;)

Le trie croissant (donc avec ASC) donne ce résultat :

192.168.1.1
192.168.1.100
192.168.1.122
192.168.1.20
192.168.1.251
192.168.1.30
0
Nuk Messages postés 177 Date d'inscription   Statut Membre Dernière intervention   20
 
Autant pour moi.^^

Tu veux classer par nombre et non pas par le premier chiffre..J'avais mal lu les resultats de requêtes.

Hum j'ai deja fait la manip mais c'etait y'a un moment et mes conaissances sql se sont etiolées....Jvais essayer de faire un effort de memoire mais je garantis rien.
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Droopy_ Messages postés 248 Date d'inscription   Statut Membre Dernière intervention   25
 
J'ai trouvé ça sur SQL server, mais ça marche pas tel quel sur MySQL :
http://www.sql-server-helper.com/tips/sort-ip-address.aspx

Ça peut être une base pour rechercher...
0