[SQL] Trié par adresse IP

Résolu/Fermé
afrodje Messages postés 759 Date d'inscription mardi 13 mars 2007 Statut Membre Dernière intervention 22 janvier 2014 - 26 nov. 2008 à 18:16
Schiver Messages postés 20 Date d'inscription vendredi 23 janvier 2009 Statut Membre Dernière intervention 24 février 2009 - 6 févr. 2009 à 15:40
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 mardi 13 mars 2007 Statut Membre Dernière intervention 22 janvier 2014 168
29 nov. 2008 à 17:47
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 vendredi 23 janvier 2009 Statut Membre Dernière intervention 24 février 2009
6 févr. 2009 à 15:40
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
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 mardi 13 mars 2007 Statut Membre Dernière intervention 22 janvier 2014 168
26 nov. 2008 à 18:23
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 mardi 13 mars 2007 Statut Membre Dernière intervention 22 janvier 2014
26 nov. 2008 à 18:34
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 lundi 10 novembre 2008 Statut Membre Dernière intervention 5 mai 2009 20
26 nov. 2008 à 18:29
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 mardi 13 mars 2007 Statut Membre Dernière intervention 22 janvier 2014 168
26 nov. 2008 à 18:31
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 lundi 10 novembre 2008 Statut Membre Dernière intervention 5 mai 2009 20
26 nov. 2008 à 18:40
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 dimanche 16 novembre 2008 Statut Membre Dernière intervention 17 janvier 2009 25
26 nov. 2008 à 20:11
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