2011-05-28 77 views
0

我做我的理學士IT大項目,我做的影院售票系統 我有3個表SQL幫助

電影

movieID movieName ticketPrice 
    1001  3 idiots  200 
    1002  ready 300 
    1003  robot 250 

時間表

showId movieId 
9001  1001 
9002  1003 
9003  1002 

門票

ticketNo showId soldBy 
21  9001  A 
73  9001  B 
23  9001  A 
22  9001  A 
64  9002  A 
34  9003  B 
11  9001  A 
98  9001  A 
38  9003  B 
78  9001  B 
24  9002  A 
31  9001  A 

我希望得到以下結果

userName showId TotalAmount(Product of Count(TicketNo) and ticketPrice) 
A   9001 1200 
A   9002 500 
B   9001 400 
B   9003 600 

請幫我

回答

2
SELECT 
    t.soldBy AS userName, 
    t.showId, 
    SUM(m.ticktPrice) AS TotalAmount 
FROM 
    tickets t 
    INNER JOIN schedule s ON s.showId = t.showId 
    INNER JOIN movies m ON m.movieId = s.movieId 
GROUP BY 
    t.soldBy, 
    t.showId 
+2

'SUM(t.ticketNo * m.ticktPrice)'應該只是'SUM(m.ticktPrice)','t.ticketNo'只是一個票證標識符。 – 2011-05-28 08:14:41

+0

謝謝,改變了它。 +1 – NGLN 2011-05-28 08:17:12

0
SELECT 
    T.`soldBy`, 
    T.`showId`, 
    SUM(M.`ticketPrice`) 
FROM 
    tickets AS T 
    INNER JOIN schedule AS S 
    ON T.`showId` = S.`showId` 
    INNER JOIN movies AS M 
    ON S.`movieID` = M.`movieID` 
GROUP BY T.`soldBy`, 
    T.`showId` ; 

只是一個想法:在許多地方,這是習慣有不同的價格,不僅是因爲電影院電影,但由於電影播放的時間(即早上更便宜,週末晚上更貴)。如果你想考慮這一點,那麼你就不應該把價格與電影聯繫起來,而應該將電影與電影聯繫起來。

+0

它does not工作.....................任何方式謝謝先前的建議我有同樣的想法,但後來我改變主意,包括價格電影表 – sanu 2011-05-28 08:37:32

+0

爲什麼它不起作用?在這裏完美工作! ;) – Bjoern 2011-05-28 08:39:06

+0

對不起,感謝它完美的作品,我鍵入廣告SUM(S.'ticketPrice')這就是爲什麼它不工作,現在它工作完美 – sanu 2011-05-28 08:58:05

1
select t.soldBy userName, t.showId showId, count(t.ticketNo) * m.tickeprice total 
from tickets t 
inner join schedule s on t.showId = s.showId 
inner join movies m on m.movieId = s.movieId 
group by t.soldBy, t.showId