Update
Thank you Root for your below answer (which I upvoted). Based on your suggestions, I was able to solve my problem. I am now using this -
try:
queryset2 = RoomBookings.objects.filter(HotelName__HotelName__icontains=hotel.HotelName)
except:
pass
This was working -
RoomBookings.objects.filter(HotelName__icontains=hotel.HotelName, RoomType__icontains= hotel.RoomType,
ArrivalDate__lt=RoomBookingsForm['DepartureDate'], DepartureDate__gt=RoomBookingsForm['ArrivalDate'])
But then I changed the HotelName field in the RoomBookings model from CharField to ForiegnKey. And now I cannot figure out how to do a reverse lookup. These are my failed attempts -
# queryset2 = RoomBookings.objects.filter(HotelName__HotelName__icontains=hotel.HotelName)
# queryset2 = RoomBookings.objects.filter(HotelName__Hotel__HotelName__icontains=hotel.HotelName)
# queryset2 = RoomBookings.objects.filter(HotelName__Hotel__HotelName_exact=hotel.HotelName)
# queryset2 = RoomBookings.objects.filter(HotelName__HotelName_exact=hotel.HotelName)
class Hotel(models.Model):
HotelName = models.CharField(max_length=60, null=False)
def __str__(self):
return self.HotelName
class RoomType(models.Model):
HotelName = models.ForeignKey(Hotel, null=True, blank=True, on_delete=models.CASCADE)
RoomType = models.CharField(max_length=60, null=False, choices=Room_Type)
def __str__(self):
return '{0}, {1}'.format(str(self.HotelName), self.RoomType)
class RoomBookings(models.Model):
User = models.ForeignKey(User, null=True, blank=True, on_delete=models.CASCADE)
HotelName = models.ForeignKey(Hotel, null=True, blank=True, on_delete=models.CASCADE)
RoomType = models.CharField(max_length=60, null=False, choices=Room_Type)
def __str__(self):
return '{0}, {1}, {2}'.format(self.HotelName, self.ArrivalDate, self.RoomType)