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

Langage PHP Discussion :

Simplification écriture (Foreach ?) pour un count(*)


Sujet :

Langage PHP

  1. #1
    Membre émérite Avatar de vttman
    Homme Profil pro
    Développeur "couteau mosellan"
    Inscrit en
    Décembre 2002
    Messages
    1 140
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur "couteau mosellan"
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 140
    Points : 2 286
    Points
    2 286
    Par défaut Simplification écriture (Foreach ?) pour un count(*)
    Bonjour,

    J'ai ce cas (habituel) où je sais que la requête va me retourner un enregistrement
    mais je passe par un foreach, y a t'il une écriture plus simple à utiliser dans ce cas ?
    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
     
    function verification_precommande ($cde){
    	$query = "select count(*) as cdejour from mes_commandes where "; 
    	$query .= "nom = '".$cde['nom']."'";
    	$query .= " and STR_TO_DATE(left(bon_cde,10), '%d-%m-%Y') = curdate()";
    	//echo ($query);
    	$result = runQuery($query);
    	if (numRows($query) > 0) {
    		foreach ($result as $tmp_verif) {
    			return $tmp_verif['cdejour'];
    		}
    	} else {
    		return -1;
    	}
    }
    Merci d'avance !
    Laurent

  2. #2
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    $query est une chaîne. Est-ce que ça ne devrait pas être numRows($result) ?

  3. #3
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    Essaie de faire un var_dump de $result pour voir comment s'appelle le premier élément du tableau.

    Peut-être $result[0]['cdejour']

  4. #4
    Membre émérite Avatar de vttman
    Homme Profil pro
    Développeur "couteau mosellan"
    Inscrit en
    Décembre 2002
    Messages
    1 140
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur "couteau mosellan"
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 140
    Points : 2 286
    Points
    2 286
    Par défaut
    Citation Envoyé par badaze Voir le message
    $query est une chaîne. Est-ce que ça ne devrait pas être numRows($result) ?
    Oui ça ça ressemble à une belle erreur, Merci !

  5. #5
    Membre émérite Avatar de vttman
    Homme Profil pro
    Développeur "couteau mosellan"
    Inscrit en
    Décembre 2002
    Messages
    1 140
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur "couteau mosellan"
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 140
    Points : 2 286
    Points
    2 286
    Par défaut
    Citation Envoyé par badaze Voir le message
    Essaie de faire un var_dump de $result pour voir comment s'appelle le premier élément du tableau.

    Peut-être $result[0]['cdejour']
    Je teste d'ici demain ! encore Merci !

  6. #6
    Membre émérite Avatar de vttman
    Homme Profil pro
    Développeur "couteau mosellan"
    Inscrit en
    Décembre 2002
    Messages
    1 140
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur "couteau mosellan"
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 140
    Points : 2 286
    Points
    2 286
    Par défaut
    Parfait !

    Pour le
    $query est une chaîne. Est-ce que ça ne devrait pas être numRows($result) ?
    En fait non mais je simplifierai cette partie (peut-être) plus tard
    =>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    function runQuery($query) {
    	$result = mysqli_query(DBi::$conn,$query);
    	while($row=mysqli_fetch_assoc($result)) {
    		$resultset[] = $row;
    	}		
    	if(!empty($resultset))
    		return $resultset;
    }
    function numRows($query) {
    	$result  = mysqli_query(DBi::$conn,$query);
    	$rowcount = mysqli_num_rows($result);
    	return $rowcount;	
    }
    Je ferme le sujet ...

  7. #7
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    C'est ce que j'avais pensé au début à propos de numRows mais j'imaginais mal qu'on puisse exécuter le query que pour compter le nombre d'enregistrements.
    Après je me suis dit qu'on pouvait mettre $result si numRows retournait count($result) d'où ma question.

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

Discussions similaires

  1. Simplification de quartier pour générateur de ville
    Par SKone dans le forum Mathématiques
    Réponses: 0
    Dernier message: 24/01/2010, 18h26
  2. [ODBC] SQLColAttribute me renvoi un type inconnu pour un count*
    Par elekis dans le forum Bibliothèques
    Réponses: 2
    Dernier message: 09/12/2008, 07h45
  3. Regroupement de valeurs ? pour un COUNT
    Par nicethe dans le forum SQL
    Réponses: 2
    Dernier message: 14/11/2008, 16h30
  4. [JSTL] boucle forEach pour deux liste en même temps
    Par ruud002 dans le forum Taglibs
    Réponses: 1
    Dernier message: 28/09/2006, 15h54
  5. [MySQL] Utilisation d'une itération foreach pour le parcours du résultat
    Par jexl dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 27/01/2006, 10h27

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