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 :

changement de valeur d'une variable par un switch


Sujet :

Langage PHP

  1. #1
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2017
    Messages : 8
    Points : 1
    Points
    1
    Par défaut changement de valeur d'une variable par un switch
    bonsoir , je débute en la programmation web et j ai un petit blocage ... j espère trouver une réponse ici ..alors alors :
    je veux initialiser une variable php puis modifier sa valeur selon les différents cas de mon "switch case" pour en faire des requettes..
    mon soucis c est que cette variable garde toujour sa valeur d'initialisation , une idée du soucis?

    voila a quoi peut ressembler mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $couleur="bleu";
    switch ($elt){
    case 1 : $couleur =vert;
    case 2 : $couleur=rouge;
    ...}
    echo $couleur; //le resultat est bleu  alors qu 'il a été modifié normalement .
    merci pour votre aide d'avance

  2. #2
    Responsable Systèmes


    Homme Profil pro
    Gestion de parcs informatique
    Inscrit en
    Août 2011
    Messages
    17 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Gestion de parcs informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Août 2011
    Messages : 17 452
    Points : 43 103
    Points
    43 103
    Par défaut
    1er point :
    Il manque des "" sur les affectations de la valeur de $chaine dans tes case.

    2ème point:
    es-tu sûre que $elt a une valeur de 1 ou 2 permettant de changer l'affectation ? Par défaut une variable n'ayant jamais eue d'affectation aura une valeur de NUL.

    3ème point :
    Il faut mettre des break à la fin de chaque clauses case, sauf dans des cas particuliers.
    http://php.net/manual/fr/control-structures.switch.php
    Ma page sur developpez.com : http://chrtophe.developpez.com/ (avec mes articles)
    Mon article sur le P2V, mon article sur le cloud
    Consultez nos FAQ : Windows, Linux, Virtualisation

  3. #3
    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
    Pour la valeur par défaut, la clause "default" est faite pour ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    switch ($elt){
    case 1: $couleur = "vert"; break;
    case 2: $couleur = "rouge"; break;
    default: $couleur = "bleu"; break;
    }
    echo $couleur;
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  4. #4
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2017
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    mercii pour vos reponses, pour ce qui est des break a la fin je les ai bel et bien mis les "" pour l affectation également y sont . mon soucis n'est pas avec le switch case je l'ai testé et il marche parfaitement bien car au début j avais une dépendance entre les "case" pour supprimer cette dépendance d'ordre j ai voulu passer par une variable : voici a quoi ressemble mon code:
    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
    $vue="secu";// qui est le nom de ma table pour le 1er select
    switch($idpd){
    case 1:
     
    		$sql1="CREATE OR REPLACE VIEW vue2 AS SELECT * FROM '".$vue."' WHERE temps='".$q."'";
    		$sql2= " SELECT * FROM vue2";
    		$vue="vue2";
     
    		break;
    case 2:
     
    		$sql1="CREATE OR REPLACE VIEW vue3 AS SELECT * FROM '".$vue."' WHERE platform='$q'";
    		$sql2="SELECT * FROM vue3";
    		$vue="vue3";
    		break;
    en affichant les requette je me retrouve tjr avec un "select from secu "... alors que je veux selectionner a partir de la derniere vue crée
    mes requette seront executé et afficheront le resultat plus bas je précise que j ai 80 case (un formulaire) si j'utilise la variable $vue c est pour éviter de forcé l'ordre de réponse

  5. #5
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Mets ça avant le switch et dis-nous ce que ça affiche comme valeur.
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  6. #6
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2017
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    en mettant un echo a idpd j'affiche mon identifiant du select il va de 1 a 70 selon le numero du select , en affichant le contenu de $vue j'affiche un bon contenu or " vue1 " ou "vue2".... mais en affichant la requette j'ai tjr "secu".... chose que je ne comprend pas .

  7. #7
    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
    $sql1="CREATE OR REPLACE VIEW vue2 AS SELECT * FROM '".$vue."' WHERE temps='".$q."'";
    		$sql2= " SELECT * FROM vue2";
    		$vue="vue2";
    tu n'as pas l'impression que les opérations sont faites à l'envers ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  8. #8
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2017
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    je n'ai pas bien compris comment ça les operations sont faite a l'envers?
    moi je veux selectionner a partir de la vue qui fut crée en dernier puis je la met a jour avec le nom de cette derniere vu ...je m 'explique:
    mon utilisateur repond a la question2 je crée une vue a partir de la table $vue= "vue2" il repond ensuite a la 5eme question : donc je crée la vue 5 a partir de la vue2 et je met a jours le contenue de $vue .....

  9. #9
    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
    Je crois que tu es en train de construire une usine à gaz.

    Tu ne nous as pas du tout expliqué cette histoire de question à laquelle répond l'utilisateur donc c'est difficile d'y comprendre quoi que ce soit.

    Tout ce que je peux te montrer c'est ce que fais ton code actuellement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $vue="secu";
     // $vue vaut "secu"
    switch($idpd){
    case 1:
                    // $vue vaut toujours "secu" donc tu fais SELECT * FROM secu à tous les coups 
    		$sql1="CREATE OR REPLACE VIEW vue2 AS SELECT * FROM '".$vue."' WHERE temps='".$q."'";
     
    		$sql2= " SELECT * FROM vue2";
    		$vue="vue2";
                    // $vue vaut maintenant "vue2" 
    		break;
    Au passage si tu as 70 valeurs possible de "idpd", tu as l'intention d'écrire 70 case ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  10. #10
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2017
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    merci pour votre réponse, oui je compte faire 70 case ils sont fait mon application est assez grande car c'est impossible de passer par autre chose ,
    ensuite oui c'est exactement ce que fait mon programme mais ce que je veux c'est d'introduire la variable dans la requette , je ne comprend pas pourquoi lors de son intégration elle prend toujouuuurs la valeur initiale et non pas d'autre valeur qui lui sont attribuer .... plus simplement dit ma variable agit telle une constante ! ou presque!
    en affichant son contenu j'ai bel et bien un contenu qui change mais en l'introduisant dans une requête elle garde sa valeur initial et ce meme si sa valeur a été modifié normalement ... chose que je ne comprend pas

  11. #11
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $nom="Hervé";
    $phrase='Son nom est '.$nom;
    $nom="Gaston";
    //et toi tu veux que $phrase donne "Son nom est Gaston"... Et tu ne comprends pas pourquoi ça reste bloqué à "Son nom est Hervé"...
    //A ce stade, si tu ne comprends pas à la troisième fois, on ne peut plus t'aider...
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  12. #12
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Salut,

    pour éviter l'écueil soulevé par sabotage, tu devrais procéder autrement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $data   = [1 => 'vert', 'rouge', 'noir']; // tes 70 valeurs possibles
    $filter = $data[$idpd] ?? 'bleu';

  13. #13
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2017
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    non cher Dendrite vous n'avez pas compris ce que je veux .... le traitement est bel est bien dans l'ordre ce que je reprend votre exemple:
    Code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $nom="Hervé";
    $phrase='Son nom est '.$nom; //afficher ici son nom est hervé
    $nom="Gaston";
    $phrase='son nom est'.$nom//mais ici afficher  gaston  et non hervé!!!
    //je fais la modification a la fin pour utilisé cette valeur a la prochaine requête ou encore au prochain echo , OR je veux a chaque fois affiché le précedent et non le courant !
    j’espère que vous comprenez mieux mon soucis .

  14. #14
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2017
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    merci Sabotage et rawsrc pour vos suggestion mais il n'est pas possible d'utiliser un tableau vu que mes 70 élément font parties de différentes catégories et la valeur initial qui est secu ou encore bleu dans l'exemple que je vous ai donné ne vas pas etre la même valeur initial pour toute les catégories or les éléments 1,2,3,..,8 sont dans une categorie differente que celle de 11,12,13,...,19 ce soucis est reglé et tout fonctionne je veux juste briser une dépendance entre les éléments d'ou a question sur les variables

  15. #15
    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
    Ce ne sont pas des "suggestions".
    Il est inconcevable d'avoir 70 cas de traitements pour une variable dans un code PHP.

    je veux a chaque fois affiché le précedent et non le courant
    Il te faut alors une variable qui stocke la valeur précédente.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  16. #16
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Citation Envoyé par faizanabila Voir le message
    //je fais la modification a la fin pour utilisé cette valeur a la prochaine requête ou encore au prochain echo , OR je veux a chaque fois affiché le précedent et non le courant !
    j’espère que vous comprenez mieux mon soucis .
    OK alors toutes mes excuses, Nabila.
    Mais il faudrait que tu donnes quelques exemples pour que l'on voit vraiment ce que tu veux.

    les éléments 1,2,3,..,8 sont dans une categorie differente que celle de 11,12,13,...,19
    As-tu le SQL de la vue de départ dans ton phpmyadmin ? On y verra plus clair je pense.
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  17. #17
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2017
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    "Sabotage " vous me proposer d'utiliser une variable qui stocke le précédent mais j'en utilise une et qui est la variable "$vue" a chaque fin de traitement je la met a jour avec le nom de la dernière vue crée et qui lors du prochain traitement sera ma vue précédente d'ou le fait d'affecter une valeur a vue a la fin de chaque traitement

  18. #18
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Je me pose la question suivante :

    Veux-tu stocker ce que l'utilisateur a cliqué précédemment comme option dans le select ?
    Du genre, il clique 69, puis 33, puis 21 etc...
    Et moi je maintiens, pourquoi faire une vue si tu la tues à chaque clic ?
    Pourquoi faire 70 vues dans ta base ?
    Il faut juste faire une requête dynamique. mais pour ça, il faut que tu nous donnes le SQL qui sert à constuire ta vue... si tu l'as.

    Dans tous les cas ce que veut te dire Sabotage, c'est que ta problématique ne correspond pas à un switch de 70 cases. Ca peut etre modélisé de façon beaucoup plus efficace.
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

Discussions similaires

  1. Evenement sur changement d0une valeur d'une variable
    Par Destiny dans le forum Windows Forms
    Réponses: 2
    Dernier message: 09/04/2008, 09h28
  2. [SQL] Détection du changement de valeur d'une variable
    Par micatmidog dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 10/06/2007, 20h22
  3. Réponses: 8
    Dernier message: 29/03/2007, 14h48
  4. [VB.NET]Test sur changement de valeur d'une variable
    Par shinji_rem dans le forum Windows Forms
    Réponses: 9
    Dernier message: 29/11/2006, 15h53
  5. Intercepter le changement de valeur d'une variable
    Par Captain_JS dans le forum C++Builder
    Réponses: 5
    Dernier message: 07/01/2005, 08h04

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