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 :

Trouvez une valeur entre X et Y [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2006
    Messages : 88
    Par défaut Trouvez une valeur entre X et Y
    Bonjour,

    Pour un tableau de prix progressif, je ne trouve pas à faire en sorte que mon panier trouve le prix à appliquer selon la quantité choisit.

    Ma base de donnée :

    ID | ID_PRODUIT | PV_HT | Q_MIN
    1 | 128 | 12 | 1
    2 | 128 | 11 | 5
    3 | 128 | 10 | 100
    etc.

    Si le client met 75 en quantité, il me faut le prix qui est à 11 €
    Merci pour votre aide. Je pense qu'il faut un foreach, mais je ne comprends rien à foreach

  2. #2
    Expert confirmé
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Par défaut
    Je pense qu'il faut un foreach, mais je ne comprends rien à foreach
    La syntaxe est tout bête:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $arr = array(1,2,3,4);
    foreach ($arr as $value) { echo $value; }
     
    // identique à
    for ($i=0;$i<count($arr);$i++) { echo $value; }
    On va faire une cherche simple:
    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
     
    // on suppose que $produits contiends ces resultats
    // ID | ID_PRODUIT | PV_HT | Q_MIN
    // 1  | 128        | 12    | 1
    // 2  | 128        | 11    | 5
    // 3  | 128        | 10    | 100
     
    $qt = '5'; // 5 produits
    $pvht = false;
     
    foreach ($produits as $prices) {
      if ($prices['Q_MIN'] > $qt) break;
      $pvht = $prices['PV_HT'];
    }
     
    if ($pvht) {
       echo "$qt produits coutent " . ($qt * $pvht) . "€";
    }
    else {
       echo "Damned, je n'ai pas trouvé de prix: c'est gratos!"
    }
    Donc on parcours la liste de prix pour le produit donné (on suppose ici que la requête séléctionne uniquement les prix pour le produit demandé bien sûr).
    On suppose également que la liste de prix est ordonée par Q_MIN (à mettre dans la requête SQL).
    On initialise la variable prix ($pvht) à false pour déterminer si le prix à été trouvé (toujours bien se protéger des cas d'erreur).
    On connait la quantité ($qt).

    Si l'élément prix ($price) courant concerne une quantité supérieure à la quantité voulue, on sort de la boucle: l'élément précédent étant celui qu'on cherchais, la recherche s'arrête.
    Sinon, on conserve le prix unitaire courant dans la variable $pvht.

    A la sortie de la boucle on a bien le prix unitaire qui correspond à notre quantité commandée.

  3. #3
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    c'est à faire dans ta requête SQL

  4. #4
    Expert confirmé
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Par défaut
    En effet, stealth35 à encore raison (il a toujours raison celui là )

    La requête pourrait être:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT MAX(PV_HT) AS PV_HT FROM produits WHERE Q_MIN <= '$qt';
    Enfin, un peu d'algo c'est toujours marrant...

  5. #5
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2006
    Messages : 88
    Par défaut
    Merci Benjamin pour tes explications détaillées avec foreach et en requete

    Je vais essayé tout çA.

  6. #6
    Expert confirmé
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Par défaut
    Utilise plutôt la requête, ce sera plus simple et surtout plus rapide.

  7. #7
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2006
    Messages : 88
    Par défaut
    Ca fonctionne mais en mettant MIN au lieu de MAX

  8. #8
    Expert confirmé
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Par défaut
    Une coquille de ma part, désolé.

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

Discussions similaires

  1. [XPATH] Rechercher une valeur entre deux valeurs min et max
    Par icicmoi dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 27/10/2008, 12h12
  2. Passer une valeur entre 2 pages asp.net
    Par giono dans le forum ASP.NET
    Réponses: 4
    Dernier message: 01/09/2008, 12h06
  3. Réponses: 4
    Dernier message: 25/05/2007, 17h04
  4. [XI] Progression d'une valeur entre 2 enregistrements
    Par Creess dans le forum SAP Crystal Reports
    Réponses: 16
    Dernier message: 23/04/2007, 11h35
  5. requête access (test d'une valeur entrée par l'utilisateur)
    Par ben5985 dans le forum Requêtes et SQL.
    Réponses: 10
    Dernier message: 30/11/2006, 08h39

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