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 :

Warning: Illegal string offset 'technicien_id' dans une boucke foreach()


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Inscrit en
    Août 2004
    Messages
    254
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 254
    Points : 69
    Points
    69
    Par défaut Warning: Illegal string offset 'technicien_id' dans une boucke foreach()
    Bonjour,

    J'extrait dans une requête deux colonnes qui sont technicien_id et nom_technicien, je les stocke dans une variable de session comme ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $reponse_techni = $bdd_MCHNMFT->query('SELECT lmt.technicien_id,nom_techicien FROM lignetravaux_materiels_techniciens lmt,techniciens tc
     where lmt.technicien_id=tc.technicien_id and  lmt.bontravaux_id='. $bontravaux_id);
     $donneestech = $reponse_techni->fetch();
       $_SESSION['intervenants'] =$donneestech;
    puis je parcours un autre tableau pour comparer si une valeur d'un tableau est présente dans l'autre par ceci
    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
     
    $reponse_tech = $bdd_MCHNMFT->query('SELECT * FROM  techniciens');
    while ($donnees_tech = $reponse_tech->fetch())
    {
     
    $trouve=false;
    foreach($_SESSION['intervenants'] as $element)
     
    {
    if ($donnees_tech['technicien_id']==$element['technicien_id'])
         {
    		 $trouve=true;
    		 break;
    	 }
    }
    ça me signale signale cette erreur, en fait il ne reconnait pas l'indice technicien_id dans le tableau associatif.

    Si vous avez des suggestions ?

    Cordialement

  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
    Ton foreach est en trop, tu n'as qu'une seule série de valeurs.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if ($donnees_tech['technicien_id'] == $_SESSION['intervenants']['technicien_id'])
    Mais le principe n'est pas bon, si tu veux croiser les données entre deux tables, il faut le faire directement en une requête.

  3. #3
    Membre du Club
    Inscrit en
    Août 2004
    Messages
    254
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 254
    Points : 69
    Points
    69
    Par défaut
    Bonjour,

    C'est pas les données entre deux table, c'est juste dans un formulaire j'ai besoin de stocker les informations se trouvant dans une table et dans un autre endroit
    j'affiche les éléments d'une autre table en zone d'options si un de ces éléments est égal a un si un des éléments stockes precedemment, la case est checked.
    voila

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

Discussions similaires

  1. [PHP 7] Trouver la valeur dans un tableau (array) : Illegal string offset
    Par tonton.odilon dans le forum Langage
    Réponses: 2
    Dernier message: 06/07/2017, 19h55
  2. [MySQL] Warning: Illegal string offset
    Par neomega0304 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 24/09/2016, 11h11
  3. Réponses: 4
    Dernier message: 11/04/2007, 12h49
  4. Réponses: 5
    Dernier message: 20/02/2007, 06h27
  5. [String] Remplacement caractères dans une chaîne
    Par Crazyblinkgirl dans le forum Langage
    Réponses: 4
    Dernier message: 19/07/2004, 11h15

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