[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
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
A voir également:
- Sql inet_aton
- Récupération serveur sql - Télécharger - Gestion de données
- Sql query - Télécharger - Gestion de données
- Sql replace plusieurs valeurs - Forum Programmation
- Delete cascade sql - Forum Programmation
- Sql pix - Forum Python
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
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
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.
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.
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
26 nov. 2008 à 18:23
Le faire en PHP, y a pas de prob, mais je dois le faire en sql...
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
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 ?
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
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.
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.
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
26 nov. 2008 à 18:31
C'est le cas ;)
Le trie croissant (donc avec ASC) donne ce résultat :
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
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
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.
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.
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
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...
http://www.sql-server-helper.com/tips/sort-ip-address.aspx
Ça peut être une base pour rechercher...
6 févr. 2009 à 15:40
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... ;-)