Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD > PHP & ODBC
PHP & ODBC Forum d'entraide sur ODBC avec PHP. Avant de poster -> FAQ ODBC
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 11/04/2007, 14h52   #1
Invité de passage
 
Inscription : avril 2007
Messages : 11
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 11
Points : 1
Points : 1
Par défaut Gérer l'état de machines

salut tous les membres,
voici mon problème,je travaille sur un logiciel de supervision réseaux,je veux faire un programme, qui affiche un message, qui indique l'état des postes que je supervise sans réafficher le même message pour les postes qui n'ont pas changé d'état.
mon problème c'est quand un poste tombe en panne il affiche le message, mais si un autre poste tombe en panne, il affiche le message pour les deux et moi je veux qu'il affiche le message que pour le deuxième étant donné que l'action sur le premier est déjà faite.
J'ai une table dans ma base qui contient les nmonitorstate,ndeviceid,dlastinternalstatetime
donc je propose de faire une autre table qui contient le state,device,time des postes qui ont eu l'action
mais je n'arrive pas à faire la comparasion entre les états non executés et qui sont déjà faite??!!

voici un aperçu de mon programme

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<?php
$host='localhost'; //Nom de la machine
$dns=''; //Nom de la source de données
$user='admin';//nom d'utilisateur et mot de passe de connection à la DNS
$passwd='admin';
$cnx=odbc_pconnect($dns,$user,$passwd,SQL_CUR_USE_ODBC) or die("could not connect base chargement"); //connexion à la base de 
$select="select nmonitorstateid,ndeviceid,dlastinternalstatetime from PivotActiveMonitorTypeToDevice minus select state,time from result";
$execution=odbc_exec($cnx,$select);
 
	    while(odbc_fetch_array($execution))//resultat de la requete
     	{
     	$nmonitorstateid=odbc_result($execution,1);
    	$ndeviceide=odbc_result($execution,2);
	    $dlastinternalstatetime=odbc_result($execution,3);
 
 
		if($nmonitorstateid=='3')
			 	 {
                 $warningMsg=' Votre poste est en panne';
	             echo $warningMsg,"\n";
$select2="insert into result values ('$nmonitorstateid','$ndeviceid','$dlastinternalstatetime')";
	            $execution2=odbc_exec($cnx,$select2);
 
                 }
}
 
 
odbc_close($cnx);//fermeture de la connection de base de données
?>
mohamed_ali est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/04/2007, 15h03   #2
Membre confirmé
 
Inscription : mai 2006
Messages : 372
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : mai 2006
Messages : 372
Points : 234
Points : 234
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
 
<?php
 
 
$host='localhost'; //Nom de la machine
$dns=''; //Nom de la source de données
$user='admin';//nom d'utilisateur et mot de passe de connection à la DNS
$passwd='admin';
$cnx=odbc_pconnect($dns,$user,$passwd,SQL_CUR_USE_ODBC) or die("could not connect base chargement"); //connexion à la base de 
$select="select nmonitorstateid,ndeviceid,dlastinternalstatetime from PivotActiveMonitorTypeToDevice minus select state,time from result";
$execution=odbc_exec($cnx,$select);
 
	    while(odbc_fetch_array($execution))//resultat de la requete
     	{
     	$nmonitorstateid=odbc_result($execution,1);
    	$ndeviceide=odbc_result($execution,2);
	    $dlastinternalstatetime=odbc_result($execution,3);
 
 
		if($nmonitorstateid=='3')
			 	 {
 
                 $warningMsg=' Votre poste est en panne';
	             echo $warningMsg,"\n";
$select2="insert into result values ('$nmonitorstateid','$ndeviceid','$dlastinternalstatetime')";
	            $execution2=odbc_exec($cnx,$select2);
 
                 }
 
 
 
}
 
 
odbc_close($cnx);//fermeture de la connection de base de données
 
?>
Si j'ai bien compri quand un poste tombe en panne tu l'affiche, et une fois cet affichage fait, tu ne veux plus le réafficher? Dans ce cas il faudrai je pense stocker dans la base de donnée le fait qu'il a deja été affiché (une fois qu'il a été affiché)
kahya est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/04/2007, 15h05   #3
Invité de passage
 
Inscription : avril 2007
Messages : 11
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 11
Points : 1
Points : 1
Etant donné que la table pivotactivemonitorstate contient l'id de device, son etat 'nmonitorstate', temps de la derniere entré en cette état courante.
j'ai créer la table result qui normalement contient les diffirents postes qui ont subi l'action.
mon probleme c'est comment enregistrér le state, deviceid, time des postes qui sont deja subi l'action.

j'ai aussi fai la requete select qui fait la diffirence entre les deux tables pour connaitres ceux qui n'ont pa subit l'action.
bref c'est compliqués, ca sera tres gentil si vous me proposer comment je doit procéder.
mohamed_ali est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/04/2007, 15h08   #4
Membre confirmé
 
Inscription : mai 2006
Messages : 372
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : mai 2006
Messages : 372
Points : 234
Points : 234
on peut avoir la structure des tables?
kahya est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/04/2007, 15h10   #5
Invité de passage
 
Inscription : avril 2007
Messages : 11
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 11
Points : 1
Points : 1
Citation:
Envoyé par kahya
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
 
<?php
 
 
$host='localhost'; //Nom de la machine
$dns=''; //Nom de la source de données
$user='admin';//nom d'utilisateur et mot de passe de connection à la DNS
$passwd='admin';
$cnx=odbc_pconnect($dns,$user,$passwd,SQL_CUR_USE_ODBC) or die("could not connect base chargement"); //connexion à la base de 
$select="select nmonitorstateid,ndeviceid,dlastinternalstatetime from PivotActiveMonitorTypeToDevice minus select state,time from result";
$execution=odbc_exec($cnx,$select);
 
	    while(odbc_fetch_array($execution))//resultat de la requete
     	{
     	$nmonitorstateid=odbc_result($execution,1);
    	$ndeviceide=odbc_result($execution,2);
	    $dlastinternalstatetime=odbc_result($execution,3);
 
 
		if($nmonitorstateid=='3')
			 	 {
 
                 $warningMsg=' Votre poste est en panne';
	             echo $warningMsg,"\n";
$select2="insert into result values ('$nmonitorstateid','$ndeviceid','$dlastinternalstatetime')";
	            $execution2=odbc_exec($cnx,$select2);
 
                 }
 
 
 
}
 
 
odbc_close($cnx);//fermeture de la connection de base de données
 
?>
Si j'ai bien compri quand un poste tombe en panne tu l'affiche, et une fois cet affichage fait, tu ne veux plus le réafficher? Dans ce cas il faudrai je pense stocker dans la base de donnée le fait qu'il a deja été affiché (une fois qu'il a été affiché)
Mai c'est sa le probleme j'arrive pa a faire cette tache, et si un autre poste tombe apres lui de 10 seconde il affiche pour les deux?!! c mon probleme..
mohamed_ali est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/04/2007, 15h16   #6
Membre confirmé
 
Inscription : mai 2006
Messages : 372
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : mai 2006
Messages : 372
Points : 234
Points : 234
Tu crée un champs "Affiche" de type texte, et lors de l'affichage des appareils qui viennent de tomber en panne tu fais une requete genre
Code :
update appareil set Affiche = 'oui' where numappareil = <ceux que tu viens d afficher>
Ensuite quand tu affiche un appareil en panne tu verrifie la valeur de son champ "Affiche" si elle est à 'non' (ou a vide) tu affiche, si elle est à 'oui' tu n'affiche pas (car il a déjà été affiché).

Ca irait comme ça?
kahya est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/04/2007, 15h23   #7
Invité de passage
 
Inscription : avril 2007
Messages : 11
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 11
Points : 1
Points : 1
Citation:
Envoyé par kahya
Tu crée un champs "Affiche" de type texte, et lors de l'affichage des appareils qui viennent de tomber en panne tu fais une requete genre
Code :
update appareil set Affiche = 'oui' where numappareil = <ceux que tu viens d afficher>
Ensuite quand tu affiche un appareil en panne tu verrifie la valeur de son champ "Affiche" si elle est à 'non' (ou a vide) tu affiche, si elle est à 'oui' tu n'affiche pas (car il a déjà été affiché).

Ca irait comme ça?
j'ai essayer ceci ,sa marche normale si ce poste reste toujours en panne, mais si ce meme device change encore son etat et devient en marche puis tombe une autre fois en panne le champ Affiche reste toujours a la valeur de action deja faite alors que je doit afficher a nouveau le message pour ce meme poste.
mohamed_ali est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/04/2007, 15h26   #8
Membre confirmé
 
Inscription : mai 2006
Messages : 372
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : mai 2006
Messages : 372
Points : 234
Points : 234
Fait évoluer ce champ? Quand il est reparé tu le remet à 'non', si il retombe en panne tu le remet à 'oui' et ainsi dessuite ?
kahya est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/04/2007, 21h11   #9
Invité de passage
 
Inscription : avril 2007
Messages : 11
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 11
Points : 1
Points : 1
Citation:
Envoyé par kahya
Fait évoluer ce champ? Quand il est reparé tu le remet à 'non', si il retombe en panne tu le remet à 'oui' et ainsi dessuite ?
commen je fait varier ce champ?!!
mohamed_ali est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/04/2007, 10h21   #10
Membre confirmé
 
Inscription : mai 2006
Messages : 372
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : mai 2006
Messages : 372
Points : 234
Points : 234
avec des Update..........
kahya 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 10h12.


 
 
 
 
Partenaires

Hébergement Web