Как извлечь случайную запись с помощью ORM от Django?

Object-Relational Mapping (ORM) в Django - это мощный инструмент, который позволяет разработчикам взаимодействовать с базой данных, используя код на Python вместо необработанных SQL-запросов. Одной из распространенных задач в веб-разработке является извлечение случайной записи из базы данных, будь то для отображения случайного предложения, продукта или любой другой части данных. В этой статье мы рассмотрим процесс настройки проекта Django и использования его ORM для извлечения случайной записи из базы данных.

Извлечение случайной записи с помощью ORM Django

Чтобы извлечь случайную запись из модели Quote с помощью ORM в Django, вы можете использовать метод order_by в сочетании с ? lookup, который указывает базе данных случайным образом упорядочивать результаты. Вот как это можно сделать:


Создайте представление: В myapp/views.py создайте представление для отображения случайной цитаты.

Python from django.shortcuts import render
from myapp.models import Quote

def random_quote(request):quote = Quote.objects.order_by('?').first()return render(request, 'random_quote.html', {'quote': quote})

Создайте шаблон URL-адреса: В myapp/urls.py создайте шаблон URL-адреса для представления.

Python from django.urls import path
from .views import random_quote

urlpatterns = [path('random/', random_quote, name='random_quote'),
]

Включите URL-адрес приложения в проект: random_record_project/urls.py включите конфигурацию URL-адреса приложения.

Python from django.contrib import admin
from django.urls import path, include

urlpatterns = [path('admin/', admin.site.urls),path('myapp/', include('myapp.urls')),
]

Создайте шаблон: В myapp/templates/random_quote.html создайте простой шаблон для отображения цитаты.

HTML <!DOCTYPE html>
<html>
<head><title>Random Quote</title>
</head>
<body><h1>Random Quote</h1><p>{{ quote.text }}</p><p><em>{{ quote.author }}</em></p>
</body>
</html>

Запустите сервер разработки:

python manage.py runserver

Перейдите на страницу со случайным предложением: откройте веб-браузер и перейдите по ссылке http://127.0.0.1:8000/myapp/random/. Вы должны видеть случайно выбранное предложение при каждом обновлении страницы.

https://media.geeksforgeeks.org/wp-content/uploads/20240806183116/1.png

Вывод

В этой статье мы показали, как настроить проект Django и использовать ORM Django для извлечения случайной записи из базы данных. Используя мощные возможности ORM в Django, вы можете легко взаимодействовать со своей базой данных с помощью кода на Python, что делает процесс разработки более эффективным и интуитивно понятным. Независимо от того, создаете ли вы простой веб-сайт или сложное приложение, понимание того, как использовать ORM Django для извлечения случайных записей, является ценным навыком, который может улучшить ваши проекты.