у меня есть две модели университета и колледжа, а в моделях колледжей есть модели University ForeignKey в моделях колледжей чем мне нужно отфильтровать во внешнем интерфейсе, я выбираю университет 1, чем показать мне все первые колледжи, связанные с университетом
class University(models.Model):
university_name = models.CharField(max_length = 128)
def __str__(self):
return self.university_name
это мои модели колледжа -
class College(models.Model):
university_name = models.ForeignKey(University, on_delete=models.CASCADE)
college_name = models.CharField(max_length = 128)
def __str__(self):
return self.college_name
Во внешнем интерфейсе html-страница, если я выбрал университет 1, чем показать список всех колледжей, связанных с этим университетом
в таблице университетов у меня есть 4 университета, и если я нажму на 1-й университет, он покажет весь список колледжей, который находится в 1-м университете, и если я нажму на 2-й университет, то отобразится весь список колледжей, связанных со 2-м университетом.
ну, вы, вероятно, захотите, чтобы Ajax делал это, но функция просмотра, которая возвращает ответ Ajax, будет делать именно то, что я сказал выше. Вам просто нужно отправить идентификатор объекта университета (по POST или GET), а в представлении получить университет с этим идентификатором и выполнить операцию фильтрации, о которой я упоминал выше.
Спасибо, Робин, я так и сделаю
у меня есть еще одна проблема, как я могу фильтровать данные в шаблонах
вы не делаете - вы делаете фильтрацию в представлении и передаете результат в шаблон
можете ли вы предложить мне ссылку, как фильтровать данные в шаблонах,
Я уже сказал, по умолчанию вы не можете. Здесь есть некоторое обсуждение (хотя оно довольно старое), включая некоторые обходные пути: stackoverflow.com/questions/223990/… . Но, как я уже сказал, ничего сложного здесь делать не надо, просто делайте свою фильтрацию в представлении, как я уже говорил.






Ваш вопрос не ясен - вы хотите, чтобы все колледжи относились к определенному университету? Если да, то если вы назовете этот университетский объект
my_university, то вам просто нуженCollege.objects.filter(university_name=my_university).