django实现增删改查分页接口

简介: django实现增删改查分页接口

django实现增删改查分页接口(小白必备)

在上篇文章中我使用nodejs实现了增删改查分页接口,这一篇我们则使用django实现。

1.创建一个django项目,命令如下

python manage.py startapp myapp

2.在你自己的myapp文件夹中的models.py中定义你们自己的模型

from django.db import models
class 名字(models.Model):
    title = models.CharField(max_length=100)
    author = models.CharField(max_length=100)

3.迁移数据库,创建模型的数据表,通过以下两行命令

python manage.py makemigrations
python manage.py migrate

4.在myapp文件夹中的views.py文件中编写处理请求

from django.core.paginator import Paginator
from django.http import JsonResponse
from myapp.models import Book
def get_books(request):
    # 获取所有书籍
    books = Book.objects.all()
    # 分页
    paginator = Paginator(books, 10) # 每页显示10条记录
    page_number = request.GET.get('page') # 获取页码参数
    page_obj = paginator.get_page(page_number)
    # 构造返回数据
    data = {
        'current_page': page_obj.number,
        'total_pages': paginator.num_pages,
        'books': [
            {'title': book.title, 'author': book.author, 'publication_date': str(book.publication_date)}
            for book in page_obj.object_list
        ]
    }
    return JsonResponse(data)
def create_book(request):
    # 获取POST请求数据
    title = request.POST.get('title')
    author = request.POST.get('author')
    publication_date = request.POST.get('publication_date')
    # 创建书籍对象并保存
    book = Book(title=title, author=author, publication_date=publication_date)
    book.save()
    return JsonResponse({'message': 'Book created successfully'})
def update_book(request, book_id):
    # 获取PUT请求数据
    title = request.PUT.get('title')
    author = request.PUT.get('author')
    publication_date = request.PUT.get('publication_date')
    # 更新书籍对象
    book = Book.objects.get(id=book_id)
    book.title = title
    book.author = author
    book.publication_date = publication_date
    book.save()
    return JsonResponse({'message': 'Book updated successfully'})
def delete_book(request, book_id):
    # 删除书籍对象
    book = Book.objects.get(id=book_id)
    book.delete()
    return JsonResponse({'message': 'Book deleted successfully'})

5.在项目的urls.py文件中配置URL路由

from django.urls import path
from myapp.views import get_books, create_book, update_book, delete_book
urlpatterns = [
    path('books/', get_books),
    path('books/create/', create_book),
    path('books/update/<int:book_id>/', update_book),
    path('books/delete/<int:book_id>/', delete_book),
]

6.运行项目

python manage.py runserver

到这里也就结束了,希望对您有所帮助。

相关文章
|
11月前
|
前端开发 关系型数据库 Python
Django入门到放弃之分页器
Django入门到放弃之分页器
|
11月前
|
存储 缓存 关系型数据库
Django后端架构开发:缓存机制,接口缓存、文件缓存、数据库缓存与Memcached缓存
Django后端架构开发:缓存机制,接口缓存、文件缓存、数据库缓存与Memcached缓存
295 0
|
11月前
|
安全 中间件 项目管理
Django 后端架构开发:分页器到中间件开发
Django 后端架构开发:分页器到中间件开发
155 1
|
11月前
|
数据可视化 安全 前端开发
基于Django的美团药品数据分析与可视化系统,有多用户功能,可增删改查数据
本文介绍了一个基于Django框架开发的美团药品数据分析与可视化系统,该系统具备多用户功能,支持数据的增删改查操作,并采用MySQL、pandas、echarts和bootstrap技术栈,为用户提供了一个高效、安全且实用的药品数据管理和分析平台。
168 0
基于Django的美团药品数据分析与可视化系统,有多用户功能,可增删改查数据
|
11月前
|
数据采集 数据可视化 数据挖掘
基于Django的数据分析可视化系统,有后台,有增删改查,实现多用户登录
本文介绍了一个基于Django框架开发的今日头条数据分析可视化系统,该系统具备后台管理、增删改查功能以及多用户登录,利用数据可视化技术为新闻媒体行业提供数据管理和决策支持。
208 0
基于Django的数据分析可视化系统,有后台,有增删改查,实现多用户登录
|
11月前
|
前端开发 关系型数据库 MySQL
Python基于Django框架图书管理系统,Bootstrap框架UI,后台EasyUI框架UI,有登录,实现增删改查的富文本效果
本文介绍了一个使用Python Django框架开发的图书管理系统,该系统采用Bootstrap框架进行前端UI设计,EasyUI框架用于后台UI界面,集成了富文本编辑器,并实现了登录及增删改查功能。
248 1
|
数据安全/隐私保护 Python
必知的技术知识:django自定义分页器
必知的技术知识:django自定义分页器
|
JSON 搜索推荐 数据库
Django REST framework数据展示技巧:分页、过滤与搜索的实用配置与实践
Django REST framework数据展示技巧:分页、过滤与搜索的实用配置与实践
|
前端开发 数据库 Python
Python Django项目下的分页和筛选查询
在Django中实现分页功能,视图函数通过`Paginator`处理数据,每页显示10条记录。URL配置支持带参数和不带参数的分页请求。前端模板使用for循环展示分页数据,包括商品信息和状态按钮,并利用分页组件导航。筛选查询视图根据GET请求的`state`参数过滤上架或下架产品,同样实现分页功能。前端添加状态选择下拉框,分页链接携带查询参数`state`确保筛选状态在翻页时保持。
112 0
|
API Python JSON
使用django创建简单restful应用接口的步骤
【6月更文挑战第2天】本文简介使用Django创建API服务涉及安装djangorestframework,创建api应用,定义URL路由,编写视图和序列化器。这个过程展示了如何用Django Rest Framework构建JSON格式的API。
133 2