CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[PHP + mySQL]

solid-snake-84
solid-snake-84
Niveau 8
15 février 2013 à 21:24:31

Bonsoir à tous,
j'aimerai pouvoir lire dans ma base de donné un tableau.
Je m'explique, j'aimerai faire ceci :

    • *****************

$myarray = array('tom', 'paul');

$req = $bdd->prepare('SELECT id FROM membre WHERE pseudo_membre = :pseudo');
$req->execute(array(
'pseudo' => $myarray
));

    • *****************

Mais bien entendu cela ne marche pas.
Sachant que le tableau "myarray" contiendra des données préalablement remplie de façon automatique et non manuelle.
Et que le tableau pourra contenir aucune donnée ou plusieurs.

Ce que j'aimerai c'est que la recherche dans la table, récupère l'id des membres portant les pseudo uniquement mentionné dans le tableau "myarray" (dans mon exemple qu'elle récupéré seulement l'id de tom et de paul).

Merci de votre aide.
Bien cordialement.
Snake.

pseuuuuuuuuuudo
pseuuuuuuuuuudo
Niveau 10
15 février 2013 à 21:59:33

En SQL tu peux effectuer une requête du type :

SELECT id FROM membre WHERE pseudo IN ('Pseudo1', 'Pseudo2', 'Pseudo3')

Cette requête te retournera les id respectifs des membres ayant pour pseudo Pseudo1, Pseudo2 ou Pseudo3.

Pour faire ça en PHP, tu peux utiliser la fonction implode() qui joint les cases de ton array en une string, par exemple :

implode(',', array('tom', 'paul')); retournera la chaîne tom,paul.

Par contre comme tu peux le voir, il faut des guillemets autour des différents pseudos dans la requête. Donc ça peut donner un truc comme :

http://wall.deblan.fr/x16e2/php/1/

Ou sinon tu as la solution bourrin et inefficace de faire une boucle.

solid-snake-84
solid-snake-84
Niveau 8
16 février 2013 à 12:08:06

Merci beaucoup pour ta réponse.
Je pense utiliser la première solution qui marche plutôt bien.

En revanche pour la méthode du "implode", je ne comprend pas comment ça peut marcher.
Parce que si il convertit le contenu du tableau en une string, quand on va lire la string dans la requette elle sera donc considéré comme fausse. Car au lieu de lire :

WHERE pseudo = "tom" OU "paul"

il va lire :

WHERE pseudo = "tom, paul" ce qui sera donc toujours faux.

Merci encore !

pseuuuuuuuuuudo
pseuuuuuuuuuudo
Niveau 10
16 février 2013 à 20:01:28

D'où l'intérêt de la syntaxe WHERE champ IN ("Valeur1", "Valeur2", ...)

solid-snake-84
solid-snake-84
Niveau 8
17 février 2013 à 20:15:36

D'accord, merci beaucoup !

Sous forums
  • Aide à l'achat Mac
  • Macintosh
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Steam Deck
  • Hardware
La vidéo du moment