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 :

[Tableaux] operation sur array, comparaison, addition


Sujet :

Langage PHP

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4
    Points : 4
    Points
    4
    Par défaut [Tableaux] operation sur array, comparaison, addition
    salut à tous

    Je tourne autour du pot avec le problème suivant :

    J'ai le resultat d'une requete dans un array à 2colonnes, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $requete[0]=array( "id" => "2344","qty" => "1");
    $requete[1]=array( "id" => "3755","qty" => "1");
    $requete[2]=array( "id" => "2344","qty" => "3");
    $requete[3]=array( "id" => "5689","qty" => "1");
    print_r($requete);
    Je veux construire un niveau tableau contenant uniquement des identifiants uniques et additionner "qty" si l'id est identique, en gros sortir en resultat :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $requeteFiltre[0]=array( "id" => "2344","qty" => "4");
    $requeteFiltre[1]=array( "id" => "3755","qty" => "1");
    $requeteFiltre[2]=array( "id" => "5689","qty" => "1");
    La piste que j'ai prise est de créer un tableau temporaire dédoublonné avec array_unique puis reparcourir le tableau pour faire mes additions, mais je ne m'en sors pas... Si quelqu'un à une piste.

  2. #2
    Membre averti Avatar de binouzzz19
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    385
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2007
    Messages : 385
    Points : 368
    Points
    368
    Par défaut
    pour remplir les tableaux, tu te sers d'une requete SQL ?

    Si oui, fais un sum(qty) et group by id
    sinon, ... ben je sais pas

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4
    Points : 4
    Points
    4
    Par défaut c'est pas bêtes mais...
    Salut merci pour ta réponse
    J'avais testé dans ce sens mais le problème c'est que ma requête est croisée, je ne suis pas sûr que ça passe, en tout cas ça me renvoie une erreur de syntaxe ;:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    $test = $db->get_results("
    	SELECT products_id, products_model, SUM(products_quantity)
    	FROM orders_products 
    	GROUP BY products_id
    	LEFT JOIN orders ON orders.orders_id = orders_products.orders_id
    	WHERE orders.date_purchased > DATE_SUB(NOW(), INTERVAL 48 HOUR)
    ");
    Retourne :
    Warning: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE orders.date_purchased > DATE_SUB(NOW(), INTERVAL 48 HOUR)' at line 5 in...

    Erreur que je n'ai pas si j'envleve les clauses sum et group by id...

  4. #4
    Membre averti Avatar de binouzzz19
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    385
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2007
    Messages : 385
    Points : 368
    Points
    368
    Par défaut
    met ton left join juste après le from

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4
    Points : 4
    Points
    4
    Par défaut c'est bon
    c'est résolu, avec la requete sql...
    Par curiosité si quelqu'un a une piste pour faire la même chose avec des array...

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

Discussions similaires

  1. operation sur array
    Par Le_ramo dans le forum MATLAB
    Réponses: 5
    Dernier message: 28/01/2012, 22h31
  2. [Tableaux] calcul sur deux array
    Par gemça dans le forum Langage
    Réponses: 5
    Dernier message: 19/12/2007, 07h29
  3. [Tableaux] Une recherche sur arrays imbriqués
    Par hpl76 dans le forum Langage
    Réponses: 6
    Dernier message: 26/06/2007, 18h43
  4. [Tableaux] Explode() sur Array ?
    Par bat2504 dans le forum Langage
    Réponses: 3
    Dernier message: 11/04/2007, 14h32
  5. [java] Tableau (operation sur les tableaux)
    Par Jessika dans le forum Collection et Stream
    Réponses: 5
    Dernier message: 04/01/2007, 13h40

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