IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> Django 基础(4)-Django 路由、一次更新多个记录(批量更新) -> 正文阅读

[Python知识库]Django 基础(4)-Django 路由、一次更新多个记录(批量更新)

一、Django 路由

Django REST framework 增加了对 Django 自动 URL 路由的支持。

from rest_framework import routers
 
router = routers.SimpleRouter()
router.register(r'users', UserViewSet)
router.register(r'accounts', AccountViewSet)
urlpatterns = router.urls

register() 方法有两个必须参数:

  • prefix - 设置这组路由的前缀。
  • viewset - 设置对应的视图集类。

或者,您也可以指定一个附加参数:

base_name - 用于创建的 URL 名称的基础。如果未设置,将根据视图集的 queryset 属性自动生成。请注意,如果视图集不包含 queryset 属性,则在注册视图集时必须设置 base_name。

上面的例子会生成以下 URL 模式:

  • URL pattern: ^users/$ Name: ‘user-list’
  • URL pattern: ^users/{pk}/$ Name: ‘user-detail’
  • URL pattern: ^accounts/$ Name: ‘account-list’
  • URL pattern: ^accounts/{pk}/$ Name: ‘account-detail’

用 @detail_route 或 @list_route 装饰的 视图上的任何方法 也将被路由。

from myapp.permissions import IsAdminOrIsSelf
from rest_framework.decorators import detail_route
 
class UserViewSet(ModelViewSet):
    ...
 
    @detail_route(methods=['post'], permission_classes=[IsAdminOrIsSelf])
    def set_password(self, request, pk=None):
        ...

会生成以下URL模式:

  • URL pattern: ^users/{pk}/set_password/$ Name: ‘user-set-password’

自定义操作的URL

如果您不想使用默认生成的 URL 模式,则可以使用 url_path 参数对其进行自定义。
例如,如果您想将我们的自定义操作的URL更改为 ^users/{pk}/change-password/$,则可以编写:

from myapp.permissions import IsAdminOrIsSelf
from rest_framework.decorators import detail_route
 
class UserViewSet(ModelViewSet):
    ...
 
    @detail_route(methods=['post'], permission_classes=[IsAdminOrIsSelf], url_path='change-password')
    def set_password(self, request, pk=None):
        ...

上面的例子现在将生成以下URL模式:

URL pattern: ^users/{pk}/change-password/$ Name: ‘user-change-password’

二、Django 基础-各种view,viewset (ReadOnlyModelViewSet)

全部更新

XXX.objects.all().update(country='USA')

update()方法会返回一个整型数值,表示受影响的记录条数
update()方法对于任何结果集(QuerySet)均有效,这意味着你可以同时更新多条记录。

全部更新,我们使用 XXX.objects.all() 去更新即可

根据界面传的主键id批量更新demo

    @list_route(methods=['post'])
    def batch_delete(self, request, *args, **kwargs):
        response_data = {'errCode': 0, 'msg': 'Success'}
        ids = self.request.data.get('ids',None)
        if ids is None:
            raise serializers.ValidationError({'message': [_("ids不能为空")]})
        Xxx.objects.filter(id__in=ids).update(columname1=0,cloumname2=True)
        return HttpResponse(json.dumps(response_data), content_type="application/json")

如上所示,使用Xxx.objects.filter()方法过滤即可, 更新多个字段时,直接使用逗号隔开,如 columname1=0,cloumname2=True。

前端传参

{
    "ids": [
        11,
        15,
        16,
        17
    ]
}

@list_route指定浏览器使用的具体http方法

rest_framework 中对于自定义的 viewset 方法提供了两种装饰器

  • list_route
  • detail_route
    区别就是 list_route 的参数不包含 pk(对应 list),而 detail_route 包含pk(对应 retrieve)
@list_route(methods=['post', 'delete'])
def custom_handler(self, request):
    pass


@detail_route(methods=['get'])
def custom_handler(self, request, pk=None):
    pass

我们使用 @list_route 直接指定了浏览器可以使用http方法。

三、参考

Django-批量更新
参考URL: https://www.cnblogs.com/songzhixue/articles/11064985.html
Django REST framework API 指南(6):路由
参考URL: https://blog.csdn.net/weixin_34082177/article/details/87985065

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-01-29 23:02:34  更:2022-01-29 23:03:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/5 8:20:10-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码