Я новичок в Django, я пытаюсь добиться того, чтобы модуль поиска продукта извлекал данные из MySQL и отвечал на запрос GET.
Вот моя модель
models.py
class CNF_BRAND(models.Model):
COMPANY_NAME = models.CharField(max_length=255)
BRAND_NAME = models.CharField(max_length=255)
BRAND_DESC = models.CharField(max_length=1024)
сериализаторы.py
class BrandSerializer(serializers.ModelSerializer):
class Meta:
model = CNF_BRAND
ПОЛУЧИТЬ ответ
{
"Status": "SUCCESS",
"Brand": [
{
"COMPANY_NAME": "Test",
"BRAND_NAME": "Test Brand",
"BRAND_DESC": "Classic",
}
]
}
views.py
response_data = {}
brand=CNF_BRAND.objects.all() #Main Cone #Man Goods
serializedProduct = BrandSerializer(brand, many=True)
response_data['Brand'] = serializedProduct.data
response = JsonResponse(response_data, status=status.HTTP_200_OK)
return HttpResponse(response,content_type="application/json")
который отлично работает.
Обновленный код
class CNF_BRAND(models.Model):
COMPANY_NAME = models.CharField(max_length=255)
BRAND_NAME = models.CharField(max_length=255)
BRAND_DESC = models.CharField(max_length=1024)
TITLE = models.CharField(max_length=21)
FAV_ICON = models.URLField(max_length=1024)
ПОЛУЧИТЬ ответ
{
"Status": "SUCCESS",
"Brand": [
{
"COMPANY_NAME": "Test",
"BRAND_NAME": "Test Brand",
"BRAND_DESC": "Classic",
}
]
}
Никаких изменений в ответе на получение. Я сделал
миграция python manage.py
python manage.py миграция
несколько раз перезапускал сервер django
Я вижу новые поля в базе данных и обновляю значения полей. Но не могу увидеть новые поля в моем ответе.
Обновлено
сериализаторы.py
class BrandSerializer(serializers.ModelSerializer):
PRODUCT = ProductSerializer(many=True)
class Meta:
model = CNF_BRAND
fields = '__all__'
Печать
Несмотря на то, что вышеуказанная проблема существует, я могу напечатать соответствующие значения в консоли.
print(brand[0].TITLE)
print(brand[0].FAV_ICON)
Консоль
My Title
https://www.google.co.in/images/branding/product/ico/googleg_lodp.ico
Ответ не получен в клиенте Rest
ПОЛУЧИТЬ ответ
{
"Status": "SUCCESS",
"Brand": [
{
"COMPANY_NAME": "Test",
"BRAND_NAME": "Test Brand",
"BRAND_DESC": "Classic",
}
]
}