CourseTopics
{
int TopicId; // Foreign-Key to Topics.Id
int CourseContentsId; -- first of 3-part FK
int Page; -- added
int SNo; -- added
PRIMARY KEY(TopicId, CourseContentsId, Page, SNo), -- for JOINing one way
INDEX (CourseContentsId, Page, SNo, TopicId) -- for JOINing the otehr way
}
Mezitím ...
Hádám že váš hlavní problém je ztělesněn v tomto jediném řádku:
To je nepraktické. Řešením je mít single tabulka pro Topic
a Page
a odlišit se od toho.