Relation entre deux tables en SQL/PHP

Résolu
persepolis7 Messages postés 58 Date d'inscription   Statut Membre Dernière intervention   -  
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   -
Bonjour,

je voudrais qu'un utilisateur puisse créer un produit et que ce produit lui soit lier dans la table des produits

soit une table avec les informations de l'utilisateur et une table produit

les informations suivante dans la table utilisateur :

Id, nom, prenom, mdp..

les informations suivante dans la table produit :

Id, IdUtilisateur, nomDuProduit, imageProduit, prix..


Je suis sur ma page d'ajout de produit auquelle, l'utilisateur n'a accès que lorsqu'il est connecté, que dois faire pour que lors d'un listing par category par exemple le nom du vendeur du produit puisse s'afficher à côter du produit ?

J'espere avoir été clair..

merci

3 réponses

jee pee Messages postés 41519 Date d'inscription   Statut Modérateur Dernière intervention   9 720
 
Bonjour,

Non ce n'est pas totalement clair ;-)

Quand tu fais l'insert dans la table produit, il faut mettre l'id de l'utilisateur connecté dans le champ idutilisateur.

Et pour afficher la liste avec le nom tu feras un :
select produit.id, nomduproduit, nom, prénom
from produit, utilisateur
where utilisateur.id = produit.idutilisateur

(je suis de la vieille école, je ne pratiquais pas le JOIN ;-)

Pour être plus clair je n'utiliserais pas dans les tables produit et utilisateur la clé nommée id, mais un nom distinct à chaque fois idproduit, idutilisateur

Cdlt

1
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 

(je suis de la vieille école, je ne pratiquais pas le JOIN ;-)

Argghhhh.... vade retro satanas... :-)
mais tu pourrais au moins utiliser les alias de table. :-)

et bonjour quand même ^^
0
persepolis7 Messages postés 58 Date d'inscription   Statut Membre Dernière intervention   1
 
Oui je viens de comprendre merci ! :)
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 

Pour être plus clair je n'utiliserais pas dans les tables produit et utilisateur la clé nommée id, mais un nom distinct à chaque fois idproduit, idutilisateur

Quelle drôle d'idée....(et quelle bêtise).
Pourquoi vouloir donner un nom distinct aux champs... sachant qu'on est dans la table..
Un exemple
Table utilisateur ( id, nom, prenom)
Pourquoi vouloir mettre
Table utilisateur ( idUtilisateur, nom, prenom) ??
Dans ce cas.. autant pousser au maximum
Table utilisateur ( idUtilisateur, nomUtilisateur, prenomUtilisateur) ....

Sachant que quand tu fais ta requête... soit tu nommes les tables soit (et c'est plus lisible...) tu utilises des alias...
SELECT 
       p.*
      ,U.id as ID_UTILISATEUR
      ,U.nom
      ,U.prenom
FROM produit P
LEFT JOIN utilisateur U ON U.id = P.idUtilisateur

De cette façon.. lorsque tu dois faire des jointures entre les tables.. tu n'as pas à te demander si tu as bien orthographié le nom du champ ... id_utilisateur ? IDUtilisateur ? idUtilisateur, id_Utilisateur ..... tu sais que c'est id ... et c'est tout.
NB: Il est également préférable de TOUJOURS nommer ses champs en MINULSCULE et sans caractères accentués ou spéciaux.

Voila...
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Bonjour
SELECT *
FROM  produit P
LEFT JOIN utilisateur U  ON U.id = P.IdUtilisateur

0
persepolis7 Messages postés 58 Date d'inscription   Statut Membre Dernière intervention   1
 
Merci mais pour l'ajout comment procède t-on ? j'ai essayé de le faire juste en bas
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752 > persepolis7 Messages postés 58 Date d'inscription   Statut Membre Dernière intervention  
 
0
persepolis7 Messages postés 58 Date d'inscription   Statut Membre Dernière intervention   1
 
Je viens de voir..
0
persepolis7 Messages postés 58 Date d'inscription   Statut Membre Dernière intervention   1
 
J'aurais besoin d'aide notamment sur les champs "Id, IdUtilisateur"

à quoi faire correspondre l'IdUtilisateur ? à l'Id de la table Utilisateur ?



prepare( "INSERT INTO produit( nomDuProduit, prix ) VALUES(?, ?) WHERE IdUtilisateur = ?" );

execute( array( $nomProduit, $prix, $_SESSION['Id'] ) );



L'Id de la table produit reste donc en autoincremente puisque c'est l'Id du produit est-ce correcte ?
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
INSERT INTO produit( nomDuProduit, prix ,IdUtilisateur ) VALUES(?, ?, ?) 

Et oui.. IdUtilisateur .. ben c'est l'id de ton utilisateur. (du vendeur vu que c'est ce que tu veux)...
0
persepolis7 Messages postés 58 Date d'inscription   Statut Membre Dernière intervention   1
 
J'étais pas sûr :) merci
0