{MySQL} creer 1 table à partir de 3

Résolu
LeGhe -  
 LeGhe -
Bonjour,

Je ne m'en sors pas... Alors que mon souci est simple :

J'ai 3 tables :
author : ID et Name
book : ID Titre et Biographie
bookxauthor : BookID et AuthorID

par exemple :
author : 1|Albert Camus
2|Hugo Pratt
book : 1|la Peste|Auteur français
2|Tango|Auteur de BD
3|Les éthiopiques|Auteur de BD
bookxauthor : 1|1
2|2
3|2

Je veux en créer une 4è reprenant author ID et Name, et book Biographie

pour avoir au final

1 Albert Camus Auteur français
2 Hugo Pratt Auteur de BD

Merci infiniment pour votre aide
A voir également:

11 réponses

dam75 Messages postés 1063 Date d'inscription   Statut Webmaster Dernière intervention   67
 
normalement le GROUP BY aurait du les eliminer ??

Sinon tu peux aussi :
CREATE TABLE table4
SELECT DISTINCT bookxauthor.AuthorID, author.Name, book.Biographie
FROM author
INNER JOIN booxauthor ON (author.ID = bookxauthor.AuthorID)
INNER JOIN book ON (bookxauthor.BookID = book.ID)
GROUP BY bookxauthor.AuthorID, author.Name, book.Biographie

Note le DISTINCT :)
2
NitroGen® Messages postés 102 Date d'inscription   Statut Membre Dernière intervention   1
 
Tu crée ta 4ème table.
mais tu peux faire un script PHP qui insert dans les 3 premières tables t'es paramètres et ensuite tu refait un INSERT INTO dans ta 4ème table.

J'espère que tu m'a compris lol
0
LeGhe
 
Bah pas des masses, je débute à peine...
0
NitroGen® Messages postés 102 Date d'inscription   Statut Membre Dernière intervention   1
 
Je vais essayer d'être plus clair ... lol
Est-ce que l'inscription se fait pas une page PHP avec un formulaire ou est-ce que c'est manuel grâce au PHPMyAdmin ???
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
LeGhe
 
Manuel via phpmyadmin
0
LeGhe
 
INSERT INTO idauteurbio (ID, DisplayName, Biographiedelauteur) SELECT ID, DisplayName FROM author SELECT Biographiedelauteur FROM book

ne fonctionne pas
0
NitroGen® Messages postés 102 Date d'inscription   Statut Membre Dernière intervention   1
 
moi je te conseil de te créer un script PHP pour avoir un formulaire que tu mettera sur ton site dans un dossier .htaccess (page protéger par Mot de Passe administrateur que personne ne peux décoder ce Mot de passe crypté)
0
dam75 Messages postés 1063 Date d'inscription   Statut Webmaster Dernière intervention   67
 
Bonjour,

Essaie ca (je garantis pas les noms exacts mais le principe y est)

CREATE TABLE table4
SELECT bookxauthor.AuthorID, author.Name, book.Biographie
FROM author
INNER JOIN booxauthor ON (author.ID = bookxauthor.AuthorID)
INNER JOIN book ON (bookxauthor.BookID = book.ID)
GROUP BY bookxauthor.AuthorID, author.Name, book.Biographie

PS modifie table4 pour l'appeler comme tu veux :)
0
LeGhe
 
BRAVO !

Et merci, je comprends enfin le bouzin !!!
Merci encore
0
LeGhe
 
Dernière question :

Comment éviter ce genre de doublon ?

212 Bill Bryson Bill Bryson est " un enfant de l'Iowa qui pratique...
212 Bill Bryson Bill Bryson est " un enfant de l'Iowa qui pratique...
212 Bill Bryson Bill Bryson est " un enfant de l'Iowa qui pratique...
0
LeGhe
 
YES !
C'est un métier ;)
Merci encore !
0