[mysql] выборка с объединением 3 таблиц
- From
- Dmitry Pljonkin (2:5020/400)
- To
- All (2:5054/37.63)
- Date
- 2005-02-12T15:23:12Z
- Area
- SU.DBMS.SQL
From: Dmitry Pljonkin <dm2029@mail.domonet.ru>
Hi!
В БД 3 таблицы:
CREATE TABLE `mis_q_tests` (
`Id` int(11) NOT NULL default '0',
`Name` varchar(255) NOT NULL default '',
PRIMARY KEY (`Id`),
);
CREATE TABLE `mis_q_questions` (
`Id` int(10) unsigned NOT NULL default '0',
`TestId` int(10) unsigned NOT NULL default '0',
`Question` text NOT NULL,
PRIMARY KEY (`Id`),
KEY `TestId` (`TestId`)
);
CREATE TABLE `mis_q_results` (
`Id` int(10) unsigned NOT NULL default '0',
`StudentId` int(10) unsigned NOT NULL default '0',
`TestId` int(10) unsigned NOT NULL default '0',
`CorrectAnswers` int(10) unsigned NOT NULL default '0',
PRIMARY KEY (`Id`),
UNIQUE KEY `un_st_test` (`StudentId`,`TestId`),
KEY `StudentId` (`StudentId`),
KEY `TestId` (`TestId`)
);
Вопрос 1:
Дают ли что-нибудь в этом случае индексы StudentId и TestId при запросах
вида "SELECT ... FROM mis_q_results WHERE TestId=.."?
Вопрос 2:
Надо при выборке получить Id теста, его название, количество вопросов и
количество результатов (т.е. сколько студентов прошли тестирование).
Как это сделать одним запросом?
Пока родил только вот это:
SELECT t1.Id, t1.Name,
count(t2.Id) AS NumQuestions,
count(t3.Id) AS NumResults
FROM mis_q_tests AS t1
LEFT JOIN mis_q_questions AS t2 ON t1.Id=t2.TestId
LEFT JOIN mis_q_results AS t3 ON t1.Id=t3.TestId
WHERE 1=1 GROUP BY t1.Id, t3.Id ORDER BY t1.Name ASC
Никак не пойму механизм работы связки join + group by
Спасибо.
--
Adios!
--- ifmail v.2.15dev5.3
* Origin: Demos online service (2:5020/400)
SEEN-BY: 46/50 50/203 520 450/159 186 1024 451/30 454/9 461/43 132 640 469/999
SEEN-BY: 4614/20 4616/3 4625/8 4627/10 5000/76 5000 5001/5001 5006/1 5007/1
SEEN-BY: 5010/53 70 5011/13 5012/23 5015/10 5019/31 5020/52 118 175 194 400
SEEN-BY: 5020/545 604 639 715 758 892 894 1042 1057 1200 1523 1604 1665 1909
SEEN-BY: 5020/1922 2013 2020 2238 4441 8383 12000 5021/29 5025/3 750 5026/10
SEEN-BY: 5026/14 45 5027/16 5029/32 5030/115 217 473 556 966 1063 1339 1900
SEEN-BY: 5031/47 5035/38 5036/1 34 5040/47 5042/13 5047/43 5049/1 5051/15
SEEN-BY: 5054/1 8 9 10 28 35 37 45 63 67 5055/95 5057/1 5059/37 5060/88
SEEN-BY: 5061/15 5062/1 5066/18 5069/7 5070/1222 5079/23 5080/68 1003 5081/2
SEEN-BY: 5082/6 5083/21 5084/32 5085/13 5090/106 5092/1 5099/133 6000/12 254
SEEN-BY: 6009/1
PATH: 5020/400 4441 545 5054/1 37