Я не получаю значение из базы данных

Я использую MVT в django. Я использую общие CBV (listview, detailview). вот мои коды

Здесь model.py

from django.db import models


class Singers(models.Model):
    name= models.CharField(max_length=256)
    age= models.IntegerField()
    gender= models.CharField(max_length=10)


class Albums(models.Model):
    name= models.CharField(max_length=256)
    singer=models.ForeignKey(Singers, on_delete=models.CASCADE)

view.py

from django.views import generic
from core.models import Albums, Singers

#in generic view instead of functions, we use classes

class AlbumView(generic.ListView):
    model = Albums
    template_name = 'index.html'
    paginate_by = 10
    def get_queryset(self):
        return Albums.objects.all()

class DetailView(generic.DetailView):
    model = Albums
    template_name = 'detailview.html'

Здесь urls.py

from django.urls import path
from core.views import AlbumView, DetailView
urlpatterns = [
    path('album/', AlbumView.as_view()),
    path('album/detail/<pk>/', DetailView.as_view())
]

Здесь index.html


{% block content %}
    <h2>Albums</h2>
    <ul>
        {% for albums in object_list %}
            <li>{{ albums.name }}</li>
        {% endfor %}
    </ul>
{% endblock %}


здесь detailview.html

{% block content %}
  <h1>name: {{Albums.name}}</h1>
  <p><strong>Singer: {{Albums.Singer}}</strong></p>
{% endblock %}

Представление деталей не работает нормально. Оно не получает соответствующие имена альбома и исполнителя.

Предложите, что мне делать?

Попробуйте это

{% block content %}
  <h1>name: {{object.name}}</h1>
  <p><strong>Singer: {{object.singer.name}}</strong></p>
{% endblock %}
class DetailView(generic.DetailView):
    model = Albums
    template_name = 'detailview.html'

Это не работает, вам нужно получить первый контекст вот так

def get_context_data(self, **kwargs):
        // Call the base implementation first to get a context
        context = super().get_context_data(**kwargs)
        // Add in a QuerySet of all the books
        context['Album_list'] = Albums.objects.all()
        return context

И вы тоже можете

context_object_name = 'publisher'
queryset = Publisher.objects.all()
Вернуться на верх