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 -
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
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
A voir également:
- Relation entre deux tables sql
- Nombre de jours entre deux dates excel - Guide
- Deux ecran pc - Guide
- Comment faire deux colonnes sur word - Guide
- Itinéraire google map entre deux adresses - Guide
- Tables des matières word - Guide
3 réponses
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 :
(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
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
J'aurais besoin d'aide notamment sur les champs "Id, IdUtilisateur"
à quoi faire correspondre l'IdUtilisateur ? à l'Id de la table Utilisateur ?
L'Id de la table produit reste donc en autoincremente puisque c'est l'Id du produit est-ce correcte ?
à 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 ?
Argghhhh.... vade retro satanas... :-)
mais tu pourrais au moins utiliser les alias de table. :-)
et bonjour quand même ^^
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...
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...