python serializer, model drf通过序列化器, 模型获取mysql 一张表某个字段数据库现存的最大值

需求, 我想获取pbr_config这张表seq_num 意为序号最大值

核心代码如下:

方法一:

复制代码
        max_seq_num = PolicyRoutingConfig.objects.aggregate(Max('seq_num'))['seq_num__max']  # 获取数据库最大序号 无数据时返回{'seq_num__max': None}
        request.data['seq_num'] = max_seq_num + 1 if max_seq_num else 1  # 若为None,则从1开始

用到了Max函数, 需要导入

复制代码
from django.db.models import  Max依赖

方法二:

policy = PolicyRoutingConfig.objects.all().order_by('-seq_num').first()

max_seq_num = policy.seq_num

sqe_num = max_seq_num + 1 if max_seq_num else 1

seq_num = policy.seq_num + 1 # 新建这一条策略的序号

serializer.validated_data['seq_num'] = seq_num

serializer.save()

model模型核心代码

复制代码
from django.db import models
复制代码
class PolicyRoutingConfig(models.Model):
    """策略路由"""
    pbr_id = models.AutoField(auto_created=True, primary_key=True, blank=True, serialize=False, help_text='策略路由序号即数据库自增id')
    seq_num = models.IntegerField(blank=True, help_text='拖拽相关参数, 序号')
    src_addr = models.CharField(max_length=64, help_text='源地址,默认any,可选择地址对象和地址组或手动输入ip/mask')
    dst_addr = models.CharField(max_length=64, help_text='目的地址,默认any,可选择地址对象和地址组或手动输入ip/mask')
    service = models.CharField(max_length=64, help_text='服务, 默认any,可选择服务和服务组')
    gateway_addr = models.CharField(max_length=64, help_text='网关地址')
    gateway_weight = models.IntegerField(default=1, help_text='网关的权重值')
    gateway_interface = models.CharField(max_length=64, help_text='网关关联的接口名称')
    priority = models.IntegerField(default=1, help_text='优先级')
    enable = models.IntegerField(help_text='是否启用 0:关闭 1:启用')

    class Meta:
        managed = True
        db_table = 'pbr_config'
        app_label = 'netset'

序列化器类核心代码

复制代码
from rest_framework import serializers
from netset.models import PolicyRoutingConfig

class PolicyRoutingSerializer(serializers.ModelSerializer):
    """策略路由配置"""
    class Meta:
        model = PolicyRoutingConfig
        fields = ('pbr_id', 'seq_num', 'src_addr', 'dst_addr', 'service', 'gateway_addr', 'gateway_weight',
                  'gateway_interface', 'priority', 'enable')
相关推荐
程序员三藏1 天前
接口测试及常用接口测试工具总结
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
小二·1 天前
Python Web 开发进阶实战 :AI 原生数字孪生 —— 在 Flask + Three.js 中构建物理世界实时仿真与优化平台
前端·人工智能·python
eWidget1 天前
InfluxDB迁移至金仓数据库的同城容灾实践:性能显著提升、运维效率优化,某能源企业实现RPO_5秒的高可靠时序数据管理
运维·数据库·能源·时序数据库·kingbase·kingbasees·金仓数据库
小句1 天前
MySQL慢查询日志详细使用指南
数据库·mysql·adb
hmywillstronger1 天前
【Rhino】【Python】 查询指定字段并cloud标注
开发语言·python
老邓计算机毕设1 天前
SSM医疗资源普查6qxol(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb开发·医疗资源管理
dyyx1111 天前
如何从Python初学者进阶为专家?
jvm·数据库·python
二十雨辰1 天前
[python]-函数
开发语言·python
CryptoRzz1 天前
如何高效接入日本股市实时数据?StockTV API 对接实战指南
java·python·kafka·区块链·状态模式·百度小程序
码农水水1 天前
中国邮政Java面试被问:容器镜像的多阶段构建和优化
java·linux·开发语言·数据库·mysql·面试·php