IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Condition sur requête [Oracle]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 9
    Points : 5
    Points
    5
    Par défaut Condition sur requête
    Bonjour à tous,

    je suis actuellement en stage pour ma 2ème année de BTS Info de gestion, et je fais appel à vos connaissances en php car je suis assez débutant dans ce langage.
    Mon problème est que j'aimerai poser une condition sur le résultat d'une requête, seulement la condition ne fonctionne qu'à moitié.

    J'explique le problème :
    Lorsque la requête ne retourne aucune ligne, affichage d'un alert(), jusque là ça fonctionne.
    Seulement, lorsque la condition est vrai (retourne 1 ou plusieurs lignes) je voudrais attribuer des valeurs à des variables avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    while ($row = oci_fetch_row($stid)) {
        $ip = $row[1];
    }
    Mais c'est là qu'est le problème... $ip ne reçoit rien, alors que sans la condition mon code fonctionne

    Voici le code plus complet, ainsi vous aurez peut être plus de chance de cerner le problème.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
    $queryIP = "select * from ut_materiel u, ut_localisation t
    			where u.id_local = t.id_local
    			and id_ip = '" . $_POST['Tb_IP'] . "'";	
     
    $stid = oci_parse($conn, $queryIP);
    if (!$stid) {
    	$e = oci_error($conn);
    	echo htmlentities($e['message']);
    	exit;
    }
     
    $r = oci_execute($stid, OCI_DEFAULT);
    if (!$r) {
    	$e = oci_error($stid);
    	echo htmlentities($e['message']);
    	exit;
    }
     
    oci_fetch_array($stid);
    if (oci_num_rows($stid) >0) {
    	while ($row = oci_fetch_row($stid)) {
    		$ip = $row[1];
    		$mac = $row[2];
    		$switch = $row[3];
    		$numPort = $row[4];
    		$pile = $row[11];
    		$bat = $row[13];
    		$etage = $row[14];
    		$piece = $row[15];
    		$prise = $row[16];
    	}
    	echo 'IP : '.$ip;
    Si ça peut vous aider également, il s'agit d'une base Oracle 10.2g et de php5.3.5.

    Voilà je vous remercie de votre aide.

    Ekow

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Enlève
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    oci_fetch_array($stid);
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    C'est bien comme ça que j'avais fait au début, seulement quand je l'enlève je ne rentre même pas dans le if, pourtant ma requête est bonne et me retourne bien 1 résultat sous SQL*Plus

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    oci_num_rows, je cite, ne retourne pas le nombre de lignes sélectionnées.
    Retire donc également cette condition.
    Elle ne sert a rien de toute facon puisque tu n'as pas le cas "else".
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    Le else est en dessous, je ne l'ai pas mis puisque je pensais qu'il n'était pas utile, lui fonctionne parfaitement.

    j'ai essayé avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    if (oci_fetch_row($stid) != false) {
    	while ($row = oci_fetch_row($stid)) {
    		$ip = $row[1];
    		$mac = $row[2];
    		$switch = $row[3];
    		$numPort = $row[4];
    		$pile = $row[11];
    		$bat = $row[13];
    		$etage = $row[14];
    		$piece = $row[15];
    		$prise = $row[16];
    	}
    	echo 'IP : '.$ip;
            ....
    } else {
        echo "<script> alert(\"IP inexistante dans la base !\"); </script>";
    }

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Ca ne peut pas marcher comme ça, tu perds la premiere ligne.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    Merci, mais oui en effet il semble que le while ne soit pas pris en compte puisque tout ce qui suit fonctionne...

    Alors pourquoi est ce qu'il n'est pas pris ? C'est ça que je me demande et qui me chagrine

  8. #8
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    while ($row = oci_fetch_row($stid)) {
    		$ip = $row[1];
    		$mac = $row[2];
    		$switch = $row[3];
    		$numPort = $row[4];
    		$pile = $row[11];
    		$bat = $row[13];
    		$etage = $row[14];
    		$piece = $row[15];
    		$prise = $row[16];
                    echo 'IP : '.$ip;
    	}
    if (!isset($ip)) {
        echo "<script> alert(\"IP inexistante dans la base !\"); </script>";
    }
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    Pourquoi j'y avais pas pensé...

    Merci beaucoup en tout cas, problème résolu

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [WD15] Condition sur requête de modification
    Par mickaeln dans le forum WinDev
    Réponses: 2
    Dernier message: 22/01/2013, 13h50
  2. Cherche la bonne condition sur une requête
    Par Tchupacabra dans le forum Langage SQL
    Réponses: 5
    Dernier message: 08/11/2006, 14h52
  3. Réponses: 3
    Dernier message: 06/10/2006, 14h55
  4. Problème de requête avec cumul des conditions sur un champ
    Par UtopieAmbiante dans le forum Requêtes
    Réponses: 4
    Dernier message: 11/01/2006, 10h52
  5. Problème: condition sur formulaire dans requête
    Par decour dans le forum Access
    Réponses: 1
    Dernier message: 17/10/2005, 23h27

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo