Mam tabelę projektów, która ma dwa klucze obce dla użytkowników (user_id i winner_user_id), jeden dla właściciela projektu i jeden dla zwycięzcy projektu. Coś takiego jak SQL, Jak zapytać z wieloma kluczami obcymi w tabeli?
+----------------+-------------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------------+-------------------------+------+-----+---------+----------------+
| project_id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| start_time | datetime | NO | | NULL | |
| end_time | datetime | NO | | NULL | |
| title | varchar(60) | NO | | NULL | |
| description | varchar(1000) | NO | | NULL | |
| user_id | int(11) | NO | | NULL | |
| winner_user_id | int(10) unsigned | YES | | NULL | |
| type | enum('fixed','auction') | YES | | NULL | |
| budget | decimal(10,0) | YES | | NULL | |
+----------------+-------------------------+------+-----+---------+----------------+
Teraz próbuję w jednym zapytaniu, aby uzyskać informacje o projektach i danych o obu użytkowników.
Więc sformułowane zapytanie jak
SELECT projects.project_id, projects.title, projects.start_time,
projects.description, projects.user_id, projects.winner_user_id,
users.username as owner, users.username as winner
FROM projects,users
WHERE projects.user_id=users.user_id
AND projects.winner_user_id=users.user_id
która zwraca pusty zestaw oczywiście. Prawdziwy problem polega na tym, jak odwołać się do tych różnych user_ids. Próbowałem nawet użyć słowa kluczowego AS, a następnie używając nazwy, którą utworzyłem w tym samym zapytaniu sql, ale najwyraźniej to nie działa.
Żeby było jasne w końcu chciałbym coś takiego
+------------+-------------------------------------------------+---------------------+---------+----------------+--------------+--------------+
| project_id | title | start_time | user_id | winner_user_id | owner | winner |
+------------+-------------------------------------------------+---------------------+---------+----------------+--------------+--------------+
| 1 | CSS HTML Tableless expert for site redesign | 2009-09-01 21:07:26 | 1 | 3 | mr X | mr Y |
| 2 | High Quality Ecommerce 3-Page Design HTML & CSS | 2009-09-01 21:10:04 | 1 | 0 | mr X | mr Z |
Jak można skonstruować zapytanie do obsługi to?
Z góry dziękuję.
dziękuję! Nigdy tak naprawdę nie używam składni INNER JOIN, ale uważam za interesujące to, że winnerUser nie jest określony bezpośrednio po FROM. – zenna