Joindre une table 'article' avec mutiple photo d'une autre table nommee 'image'
Résolu
ir_1997
Messages postés
97
Date d'inscription
Statut
Membre
Dernière intervention
-
ir_1997 Messages postés 97 Date d'inscription Statut Membre Dernière intervention -
ir_1997 Messages postés 97 Date d'inscription Statut Membre Dernière intervention -
salut tous le monde
enfaite j'ai join deux tables dont articles et images puis une colonne 'idarticle' dans la table images qui comporte l'id des article le truc et que j aimerai afficher chaque article avec ces images
mais la sa me sa m'affiche qu'un seul article et une seule photo
les autres ne s'affiches pas carement
enfaite j'ai join deux tables dont articles et images puis une colonne 'idarticle' dans la table images qui comporte l'id des article le truc et que j aimerai afficher chaque article avec ces images
mais la sa me sa m'affiche qu'un seul article et une seule photo
les autres ne s'affiches pas carement
<?php $bdd = new PDO("mysql:host=127.0.0.1;dbname=espace_membre;charset=utf8", "root", ""); $requser = $bdd->prepare('SELECT articles.article,images.image,articles.description,articles.prix,articles.contacte FROM articles join images on images.idarticle = articles.id '); $requser->execute(array()); $resultat = $requser->fetch(); {?> <table> <?php?> <tr> <ul> <h3><td> <?php echo $resultat ['article' ]."</br>";?><td></h3> <td> <img src="<?php echo $resultat ['image']?>" weight = 100 height = 100> </td> <td> <?php echo $resultat ['description']."</br>";?></td> <td> <?php echo $resultat ['prix']."</br>";?></td> <td> <?php echo $resultat ['contacte']."</br>"; ?></td> </ul> </tr> <?php }?>
A voir également:
- Joindre une table 'article' avec mutiple photo d'une autre table nommee 'image'
- Table ascii - Guide
- Table des matières word - Guide
- Google photo - Télécharger - Albums photo
- Légender une image - Guide
- Tableau croisé dynamique ou table de pilote - Guide
8 réponses
Bonjour
Déjà es tu sur sqlserver (choix de ton forum....) Ou, comme je le pense... MySQL ?
Edit: vu la chaîne de connexion.. c'est MySQL..
Je déplace donc dans le bon forum
Ensuite... Je pense qu'il suffit d'inverser ton from et ton join
Déjà es tu sur sqlserver (choix de ton forum....) Ou, comme je le pense... MySQL ?
Edit: vu la chaîne de connexion.. c'est MySQL..
Je déplace donc dans le bon forum
Ensuite... Je pense qu'il suffit d'inverser ton from et ton join
FROM images join articles
Fatal error: Uncaught PDOException: SQLSTATE[42000]: Syntax error or access violation: 1066 Not unique table/alias: 'articles' in C:\xampp\htdocs\Electronique.php:20 Stack trace: #0 C:\xampp\htdocs\Electronique.php(20): PDO->query('SELECT * FROM i...') #1 {main} thrown in C:\xampp\htdocs\Electronique.php on line 20
<?php try{ $bdd =new PDO('mysql:host=localhost; dbname=espace_membre; charset=utf8', 'root', ''); // Activation des erreurs PDO $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // mode de fetch par défaut : FETCH_ASSOC / FETCH_OBJ / FETCH_BOTH $bdd->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); } catch(PDOException $e) { die('Erreur : ' . $e->getMessage()); } ?> <!DOCTYPE html> <html> <head> <title>electronique</title> </head> <body> <?php $requete = $bdd->query( "SELECT * FROM images articles join articles where articles.idarticle = images.id " ); while($resultat =$requete->fetchALL()) {?> <table> <tr> <ul> <td><?php echo $resultat ['article']?>"</br>"; <td> <td><img src="<?php echo $resultat ['image']?>" weight = 100 height = 100> <td> <?php echo $resultat ['description']?>"</br>";</td> <td> <?php echo $resultat ['prix']."</br>";?></td> <td> <?php echo $resultat ['contacte']."</br>"; ?></td> <td> <?php echo $resultat ['date_time_publication']."</br>"; ?></td> <td> </td> <a href = "articles.php?idarticle=<?php echo $resultat ['idarticle'];?> "> plus </a> "</ul> </tr> <?php }?> </body> </html>
justement id c'est pour la table articles
et idarticle pour la table images
Fatal error: Uncaught PDOException: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'articles.idarticle' in 'where clause' in C:\xampp\htdocs\Electronique.php:20 Stack trace: #0 C:\xampp\htdocs\Electronique.php(20): PDO->query('SELECT *\r\n FROM...') #1 {main} thrown in C:\xampp\htdocs\Electronique.php on line 20
mais le problème persiste
et idarticle pour la table images
Fatal error: Uncaught PDOException: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'articles.idarticle' in 'where clause' in C:\xampp\htdocs\Electronique.php:20 Stack trace: #0 C:\xampp\htdocs\Electronique.php(20): PDO->query('SELECT *\r\n FROM...') #1 {main} thrown in C:\xampp\htdocs\Electronique.php on line 20
mais le problème persiste
<?php try{ $bdd =new PDO('mysql:host=localhost; dbname=espace_membre; charset=utf8', 'root', ''); // Activation des erreurs PDO $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // mode de fetch par défaut : FETCH_ASSOC / FETCH_OBJ / FETCH_BOTH $bdd->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); } catch(PDOException $e) { die('Erreur : ' . $e->getMessage()); } ?> <!DOCTYPE html> <html> <head> <title>electronique</title> </head> <body> <?php $requete = $bdd->query( "SELECT * FROM images Join articles where articles.idarticle = images.id " ); while($resultat =$requete->fetchALL()) {?> <table> <tr> <ul> <td><?php echo $resultat ['article']?>"</br>"; <td> <td><img src="<?php echo $resultat ['image']?>" weight = 100 height = 100> <td> <?php echo $resultat ['description']?>"</br>";</td> <td> <?php echo $resultat ['prix']."</br>";?></td> <td> <?php echo $resultat ['contacte']."</br>"; ?></td> <td> <?php echo $resultat ['date_time_publication']."</br>"; ?></td> <td> </td> <a href = "articles.php?idarticle=<?php echo $resultat ['idarticle'];?> "> plus </a> "</ul> </tr> <?php }?> </body> </html>
Non seulement tu ne sais pas lire le contenu du message d'erreur... qui est pourtant ultra clair ...
mais en plus tu ne lis pas les réponses qu'on te donne :!!!!
A remplacer par
ensuite, soit tu fais un while .. soit un fetchAll ...
Donc cette ligne
est à changer par
ou par
mais en plus tu ne lis pas les réponses qu'on te donne :!!!!
$requete = $bdd->query( "SELECT * FROM images Join articles where articles.idarticle = images.id " );
A remplacer par
$requete = $bdd->query( "SELECT * FROM images Join articles where images .idarticle = articles.id " );
ensuite, soit tu fais un while .. soit un fetchAll ...
Donc cette ligne
while($resultat =$requete->fetchALL())
est à changer par
while($resultat =$requete->fetch())
ou par
$res =$requete->fetchAll(); foreach( $res as $resultat )
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bonjour,
Ton tag HTML pour afficher les images est mal écrit.
Remplace
par
Par ailleurs, tu fais une boucle sur tous les résultats, mais il faut garder en tête que tu auras des doublons de lignes article sur ceux qui ont plusieurs images. Si ce n'est pas ce que tu veux, il faudra réfléchir à comment tu veux afficher ces images multiples.
Xavier
(PS accessoirement, intervertir le FROM et le INNER JOIN (idem avec FULL OUTER JOIN) n'a aucun effet autre que modifier l'ordre de sortie des colonnes avec *)
Ton tag HTML pour afficher les images est mal écrit.
Remplace
<td><img src="<?php echo $resultat ['image']?>" weight = 100 height = 100>
par
<td><img src="<?php echo $resultat['image']?>" width="100" height="100"></td>
Par ailleurs, tu fais une boucle sur tous les résultats, mais il faut garder en tête que tu auras des doublons de lignes article sur ceux qui ont plusieurs images. Si ce n'est pas ce que tu veux, il faudra réfléchir à comment tu veux afficher ces images multiples.
Xavier
(PS accessoirement, intervertir le FROM et le INNER JOIN (idem avec FULL OUTER JOIN) n'a aucun effet autre que modifier l'ordre de sortie des colonnes avec *)
d'accord je viens d'appliquer tes consigne
les images s'affichent
mais pour éviter les double article sur pour les images
ya aucun moyen?
les images s'affichent
mais pour éviter les double article sur pour les images
ya aucun moyen?
$requete = $bdd->query( "SELECT * FROM articles Join images where images.idarticle = articles.id " );
non j'aimerais plutôt chaque articles avec ces images
Oui ça j'ai bien compris, mais tu ne réponds pas à la question : disposées comment ?
Voici un exemple qui les place côte-à-côte :
Le principe étant de détecter qu'on change d'article, pour n'écrire les données hors photos, et le <tr>, qu'une seule fois par article. Ce qui implique de garder en mémoire la ligne précédente pour pouvoir la clore quand on a détecté un changement d'article.
Xavier
Voici un exemple qui les place côte-à-côte :
<?php try{ $bdd =new PDO('mysql:host=localhost; dbname=espace_membre; charset=utf8', 'root', ''); // Activation des erreurs PDO $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // mode de fetch par défaut : FETCH_ASSOC / FETCH_OBJ / FETCH_BOTH $bdd->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); } catch(PDOException $e) { die('Erreur : ' . $e->getMessage()); } ?> <!DOCTYPE html> <html> <head> <title>electronique</title> </head> <body> <?php $requete = $bdd->query( "SELECT * FROM images JOIN articles WHERE articles.id = images.idarticle " ); ?> <table> <?php $previousId = -1; while($resultat = $requete->fetchALL()) { $id = $resultat['id']; $newRow = $previousId > -1 && $previousId != $id; if ($newRow) { if ($previousId > -1) {?> </td> <td><?php echo $previous['description']?></td> <td><?php echo $previous['prix']?></td> <td><?php echo $previous['contacte']?></td> <td><?php echo $previous['date_time_publication']?></td> <td><a href="articles.php?idarticle=<?php echo $previousId ?>">plus</a></td> </tr> <?php } $previousId = $id; $previous = $resultat; ?> <tr> <td><?php echo $resultat['article']?></td> <td> <?php }?> <img src="<?php echo $resultat['image']?>" width="100" height="100"> <?php } if ($previousId > -1) {?> </td> <td><?php echo $previous['description']?></td> <td><?php echo $previous['prix']?></td> <td><?php echo $previous['contacte']?></td> <td><?php echo $previous['date_time_publication']?></td> <td><a href="articles.php?idarticle=<?php echo $previousId ?>">plus</a></td> </tr> <?php }?> </table> </body> </html>
Le principe étant de détecter qu'on change d'article, pour n'écrire les données hors photos, et le <tr>, qu'une seule fois par article. Ce qui implique de garder en mémoire la ligne précédente pour pouvoir la clore quand on a détecté un changement d'article.
Xavier
Et bien bien entendu.. boucler sur le résultat de ta requête...
Au passage, applique les consignes données ici :
https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
.