Django QuerySet对象,get()方法

模型参考上一章内容:

Django QuerySet对象,filter()方法-CSDN博客

Django的QuerySet对象的get()方法用于从数据库中获取单个对象。

1,添加视图函数

Test/app11/views.py

复制代码
from django.shortcuts import render
from .models import Post

def index(request):
    posts = Post.objects.all()
    return render(request, '11/index.html', {'posts': posts})



# apps/books/views.py

from django.shortcuts import render
from .models import Book

def book_list_view(request):
    # 使用filter()方法获取所有价格在10到20之间的书籍
    # books = Book.objects.filter(price__gte=10, price__lte=20)  # __gte是"greater than or equal to"(大于等于)的缩写,__lte是"less than or equal to"(小于等于)的缩写。
    # books = Book.objects.filter(price__gt=10)   # 在Django的ORM(对象关系映射)查询中,__gt是过滤条件的一个特殊语法,用于表示"大于"(greater than)。
    books = Book.objects.filter(price__lt=29.99)   # __lt 是"less than"(小于)的缩写。
    return render(request, '11/book_list.html', {'books': books})

def get_book_view(request):
    try:
        # 使用get()方法获取标题为"Python Cookbook"的书籍
        book = Book.objects.get(id=19)
        # 现在book变量包含了匹配的书籍对象
        print(book)
        return render(request, '11/book_detail.html', {'book': book})
    except Book.DoesNotExist:
        # 如果没有找到匹配的书籍,返回错误信息
        return HttpResponse("Book not found.")
    except Book.MultipleObjectsReturned:
        # 如果找到多个匹配的书籍,返回错误信息
        return HttpResponse("Multiple books found with the same title.")

2,添加html代码

Test/templates/11/book_detail.html

复制代码
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>书籍列表</title>
</head>
<body>
    <h2>书籍:{{ book }}</h2>
    <h1>{{ book.title }}</h1>
    <p>作者: {{ book.author }}</p>
    <p>日期: {{ book.publication_date }}</p>
    <p>价格: {{ book.price }}</p>
</body>
</html>

3,添加路由地址

Test/app11/urls.py

复制代码
from django.urls import path
from . import views

urlpatterns = [
    path('index/', views.index, name='index'),
    path('book_list_view/', views.book_list_view, name='book_list_view'),
    path('get_book_view/', views.get_book_view, name='get_book_view'),
]

4,访问页面

http://127.0.0.1:8000/app11/get_book_view/

可以看到成功获取到了id为19的数据了

相关推荐
yexuhgu2 分钟前
Redis怎样节省海量状态存储内存_利用Bitmap结构替代传统String存储
jvm·数据库·python
极光代码工作室3 分钟前
基于大数据的交通流量分析系统
大数据·hadoop·python·数据分析·数据可视化
彭于晏Yan3 分钟前
HttpServletRequest 如何读取JSON请求体
spring boot·后端·json
小李云雾4 分钟前
慧校坊-二手校园交易平台-------项目总结
数据库·后端·程序人生·fastapi·项目
2301_779622417 分钟前
如何修复SQL嵌套查询死锁_调整锁粒度与执行顺序
jvm·数据库·python
iAm_Ike8 分钟前
HTML怎么显示灵感便签关联项目_HTML拖拽绑定项目入口【详解】
jvm·数据库·python
2301_8092047011 分钟前
SQL如何实现实时数据的滑动窗口分析_SQL性能调优
jvm·数据库·python
木子墨51611 分钟前
工程算法实战 | 数据库ORDER BY的底层:内存排序 → 外部归并 → 索引优化
数据结构·数据库·python·sql·算法·动态规划
yexuhgu12 分钟前
如何在 JavaScript 循环中动态构建 HTML 字符串
jvm·数据库·python
wang3zc15 分钟前
使用BERTopic对名言数据集进行批量主题建模的完整实践指南
jvm·数据库·python