Précédent   Forum des professionnels en informatique > Bases de données > MySQL > Requêtes
Requêtes Forum d'entraide sur les requêtes MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 04/02/2012, 12h54   #1
Invité de passage
 
Homme
Administrateur systèmes et réseaux
Inscription : février 2012
Messages : 3
Détails du profil
Informations personnelles :
Sexe : Homme

Informations professionnelles :
Activité : Administrateur systèmes et réseaux
Secteur : Industrie

Informations forums :
Inscription : février 2012
Messages : 3
Points : 0
Points : 0
Par défaut Requête substring_index help

Bonjour,

Je post ici car j'arrive au bout de mes maigres compétences en SQL et cherche donc une réponse auprès de grands maîtres ...

Voila je fais un select:
Code :
1
2
3
4
5
 
SELECT h.PROCESSORN, h.MEMORY, h.LASTCOME, h.OSNAME,n.IPADDRESS AS ip ,h.name 
FROM web.networks n, web.hardware h 
WHERE n.HARDWARE_ID = h.ID AND n.IPADDRESS LIKE '172.22.56%'  
ORDER BY inet_aton(ip) ASC;
dans une base. Tout est nickel sauf que certaines valeurs pour le IPADDRESS me sont renvoyés ainsi dans une case séparée par des virgules:
Citation:
8, 32768, '2012-02-03 13:49:52', 'Microsoft Windows Server 2003 R2 Enterprise x64 Edition', '172.22.56.110,172.22.56.12,172.22.56.123,172.22.56.122,172.22.56.11,172.22.56.40', 'machine_hostname'
Je souhaiterai donc pouvoir modifier ma requête pour avoir une adresse IP par ligne ainsi:
Citation:
8, 32768, '2012-02-03 13:49:52', 'Microsoft Windows Server 2003 R2 Enterprise x64 Edition', '172.22.56.110, 'machine_hostname'

8, 32768, '2012-02-03 13:49:52', 'Microsoft Windows Server 2003 R2 Enterprise x64 Edition', '172.22.56.12, 'machine_hostname'
....
. J'ai vu que la fonction substring_index() pour découper en utilisant la "," comme séparateur mais je ne parvient à rien . Si quelqu'un peut donc me filer un coup de main ce serait top sinon bonn route quand même !

Cdlt,
marsu198319 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/02/2012, 14h50   #2
Modérateur
 
Avatar de CinePhil
 
Homme Philippe Leménager
Ingénieur d'études en informatique
Inscription : août 2006
Messages : 11 029
Détails du profil
Informations personnelles :
Nom : Homme Philippe Leménager
Âge : 48
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations professionnelles :
Activité : Ingénieur d'études en informatique
Secteur : Enseignement

Informations forums :
Inscription : août 2006
Messages : 11 029
Points : 18 331
Points : 18 331
Envoyer un message via MSN à CinePhil
Ça veut dire que pour une ligne de données, la colonne IPADDRESS peut contenir plusieurs adresses IP ?
=> Erreur de modélisation des données !

1er principe des bases de données relationnelles : une colonne = 1 valeur par ligne.
__________________
Philippe Leménager. Ingénieur d'étude à l'École Nationale de Formation Agronomique.
Mon blog sur la conception des BDD, le langage SQL, le PHP avec Zend Framework...
« Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
À la maison comme au bureau, j'utilise Mandriva Linux ou Mageïa ! Soutenons l'industrie logicielle française !
Linuxiens, comptez-vous !
CinePhil est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/02/2012, 15h15   #3
Invité de passage
 
Homme
Administrateur systèmes et réseaux
Inscription : février 2012
Messages : 3
Détails du profil
Informations personnelles :
Sexe : Homme

Informations professionnelles :
Activité : Administrateur systèmes et réseaux
Secteur : Industrie

Informations forums :
Inscription : février 2012
Messages : 3
Points : 0
Points : 0
Je suis bien d'accord avec toi en fait il s'agit de la bdd fourni par le produit ocs pour faire de l'inventaire. Je ne peux donc pas revoir la modélisation pas de solutions possibles alors ?
marsu198319 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/02/2012, 17h34   #4
Membre régulier
 
Homme Francis Lennert
Développeur informatique
Inscription : novembre 2011
Messages : 52
Détails du profil
Informations personnelles :
Nom : Homme Francis Lennert
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : novembre 2011
Messages : 52
Points : 86
Points : 86
Pour extraire des IP avec substring_index la syntaxe sera

Code SQL :
1
2
 
SELECT substring_index( substring_index( IPADRESS ,",",3),",",-1 )
va te renvoyer la troisième adresse IP avec "," comme séparateur.

Code SQL :
1
2
 
SELECT substring_index( substring_index( IPADRESS ,",",2 ),",",-1 )
la deuxième ...

Bon weekend.
Grandal est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/02/2012, 18h10   #5
Invité de passage
 
Homme
Administrateur systèmes et réseaux
Inscription : février 2012
Messages : 3
Détails du profil
Informations personnelles :
Sexe : Homme

Informations professionnelles :
Activité : Administrateur systèmes et réseaux
Secteur : Industrie

Informations forums :
Inscription : février 2012
Messages : 3
Points : 0
Points : 0
Merci pour ta réponse, le problème est que le nombre d'ip présente est variable, y t'il un moyen de compter via une boucle le nombre de virgule en SQL pour ensuite ajouter le nombre de substr qui va bien ?

Cdlt,
marsu198319 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/02/2012, 10h25   #6
Membre régulier
 
Homme Francis Lennert
Développeur informatique
Inscription : novembre 2011
Messages : 52
Détails du profil
Informations personnelles :
Nom : Homme Francis Lennert
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : novembre 2011
Messages : 52
Points : 86
Points : 86
Code SQL :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
 
 
CREATE DEFINER=`root`@`localhost` FUNCTION `CountTheIP`(pToCount char(255) ,pSeparator char(1)) RETURNS int(11)
    NO SQL
Begin
 
Declare X integer DEFAULT 1 ;
 
While locate( pSeparator, pToCount ) > 0 Do 
   SET X = X + 1 ;
   SET pToCount = mid( pTocount , locate( pSeparator , pToCount) +1 ) ;
End While ;
 
RETURN X ;
 
End;

Rajoute cette fonction et ensuite
Code SQL :
1
2
 
SELECT CountTheIP("'172.22.56.110,172.22.56.12,172.22.56.123,172.22.56.122,172.22.56.11,172.22.56.40'" , "," )

Renverra 6.

Bon dimanche
Grandal est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 17h52.


 
 
 
 
Partenaires

Hébergement Web