|
Как делать выборку из двух таблиц связанных промежуточной таблицой (многие ко кмногим)
|
|||
---|---|---|---|
#18+
То есть, есть две таблицы, скажим книги и авторы. В промежуточной таблице, которая связывает две эти таблицы отношением многие ко многим, храниться id книги и id автора. Мне нужно как-то сделать выборку в таблицу, в которой каждой книге сопостовляются все авторы связанные с ней (book_id - author_id). Помогите пожалуйста. ... |
|||
:
Нравится:
Не нравится:
|
|||
13.04.2011, 20:46 |
|
Как делать выборку из двух таблиц связанных промежуточной таблицой (многие ко кмногим)
|
|||
---|---|---|---|
#18+
То есть, есть две таблицы, скажим книги и авторы. В промежуточной таблице, которая связывает две эти таблицы отношением многие ко многим, храниться id книги и id автора. Хотелось-бы как-то сделать выборку в таблицу, в которой каждой книге сопостовляются все авторы связанные с ней. Т.е. [h]BOOKS[/h] Код: plaintext 1. 2. 3. 4. 5.
[h]BOOK_AUTHORS[/h] Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12.
[h]AUTHORS[/h] Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12.
Результат должен быть, что-то наподобии вот этого: Код: plaintext 1. 2. 3. 4. 5.
... |
|||
:
Нравится:
Не нравится:
|
|||
13.04.2011, 22:16 |
|
Как делать выборку из двух таблиц связанных промежуточной таблицой (многие ко кмногим)
|
|||
---|---|---|---|
#18+
mishaark, Нет, так сделать на "чистом" SQL нельзя. Надо писать процедурку/функцию. Основная сложность здесь состоит не в выборке, а в соединении имен нескольких авторов в одну строку. Эту работу и будет делать процедура/функция... ... |
|||
:
Нравится:
Не нравится:
|
|||
14.04.2011, 09:37 |
|
|
start [/forum/topic.php?fid=41&msg=37217094&tid=1584434]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
92ms |
get topic data: |
10ms |
get forum data: |
3ms |
get page messages: |
37ms |
get tp. blocked users: |
1ms |
others: | 311ms |
total: | 484ms |
0 / 0 |