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 :

Modifier valeurs d'un tableau multidimensionnel si des valeurs existent déjà [PHP 5.0]


Sujet :

Langage PHP

  1. #1
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut Modifier valeurs d'un tableau multidimensionnel si des valeurs existent déjà
    Bonjour,

    Je suis en galère sur l'utilisation d'un tableau multidimensionnel.

    Je parcours des résultats d'une base de données, et je mets des renseignements dans mon tableau

    Voici mon exemple:
    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
    array (size=15)
      0 => 
        array (size=17)
          0 => string '412623-020' (length=10)
          1 => string '210117' (length=6)
          2 => string '12.000' (length=6)
          3 => string '' (length=0)
          4 => string '' (length=0)
          5 => string 'ADC110399 9005' (length=14)
          6 => string 'COLONNE...' (length=49)
          7 => float 1.2
          8 => float 0.05
          9 => string '20220406' (length=8)
          10 => string 'centre de charge' (length=16)
          11 => string 'matière' (length=8)
          12 => string 'colorant' (length=8)
          13 => string 'nb_empreinte' (length=12)
          14 => string '1' (length=1)
          15 => string 'durée ss traitance' (length=19)
          16 => string 'outil' (length=5)
      1 => 
        array (size=17)
          0 => string '412623-020' (length=10)
          1 => string '210117' (length=6)
          2 => string '12.000' (length=6)
          3 => string '' (length=0)
          4 => string '' (length=0)
          5 => string 'ADC110399 9005' (length=14)
          6 => string 'COLONNE...' (length=49)
          7 => float 1.64
          8 => float 0.05
          9 => string '20220406' (length=8)
          10 => string 'centre de charge' (length=16)
          11 => string 'matière' (length=8)
          12 => string 'colorant' (length=8)
          13 => string 'nb_empreinte' (length=12)
          14 => string '1' (length=1)
          15 => string 'durée ss traitance' (length=19)
          16 => string 'outil' (length=5)
    Ce que je veux faire:
    lorsque j'insère un nouveau sous tableau dans mon principal, si j'ai déjà une double entrée existante (ici 0 => string '412623-020' et 1 => string '210117' ) alors je ne rajoute pas, mais je mets à jour certains champs

    Pouvez-vous m'aider svp?

    Merci beaucoup
    Xavier

  2. #2
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 043
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 043
    Points : 8 075
    Points
    8 075
    Billets dans le blog
    17
    Par défaut
    Tu peux indexer tes enregistrements (les sous-tableaux) selon les couples clefs " [0 => string '412623-020' et 1 => string '210117'] "

    Ainsi dans ta boucle un simple isset() permettra de savoir si l'enregistrement est déjà dans ton tableau ou pas et d'agir en conséquence.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $sql = 'SELECT ALL ...';
    $records = $pdo->query($sql);
    $data = [];
    foreach ($records as $record) {
        $key = $record[0] . '//' . $record[1]; // Clef d'indexation
        if (isset($data[$key])) { // Enregistrement déjà inséré ?
            // Si oui traitement de màj $data[$key]
        } else {
            $data[$key] = $record; // Si non simple insertion
        }
    }

    Sinon, vu que les enregistrements viennent d'une BdD, tu dois pouvoir sortir directement le résultat attendu.
    Un problème exposé clairement est déjà à moitié résolu
    Keep It Smart and Simple

  3. #3
    Membre éclairé
    Avatar de Asdorve
    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    1 332
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 332
    Points : 718
    Points
    718
    Par défaut
    Citation Envoyé par Séb. Voir le message
    Tu peux indexer tes enregistrements (les sous-tableaux) selon les couples clefs " [0 => string '412623-020' et 1 => string '210117'] "

    Ainsi dans ta boucle un simple isset() permettra de savoir si l'enregistrement est déjà dans ton tableau ou pas et d'agir en conséquence.
    C'est parfait ça, tout simplement ^^

    Merci beaucoup
    Xavier

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

Discussions similaires

  1. Supprimer des valeurs dans un tableau multidimensionnel
    Par JCB1980 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 11/02/2022, 19h13
  2. Réponses: 2
    Dernier message: 10/04/2020, 18h54
  3. Réponses: 4
    Dernier message: 23/03/2007, 10h40
  4. Réponses: 4
    Dernier message: 06/03/2007, 14h35
  5. Réponses: 2
    Dernier message: 08/12/2005, 15h41

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