Django 对数据库的增删改查

新增

使用方法:类模型.objects.create

类模型

python 复制代码
from django.db import models


# Create your models here.
class Car(models.Model):
    user = models.CharField(max_length=200)
    plate_number = models.CharField(max_length=20)

    def __str__(self):
        return f'{self.user} --{self.plate_number}'

请求方法

python 复制代码
from django.http import JsonResponse
from django.views.decorators.http import require_http_methods
import json

@require_http_methods(["POST"])
def my_first_request(request):
    try:
        # 读取并解析 JSON 请求体
        data = json.loads(request.body.decode('utf-8'))
        user = data.get('user')
        plate_number = data.get('plate_number')

        # 检查参数是否为空
        if not user or not plate_number:
            return JsonResponse({'error': 'params not null'}, status=400)

        # 创建并保存 Car 实例
        Car.objects.create(user=user, plate_number=plate_number)

        return JsonResponse({'success': 'Car created successfully'})

    except Exception as e:
        return JsonResponse({'error': str(e)}, status=500)

修改

save()

同时具备新增和修改功能

保存

Car.save() 是 Django 中的模型实例方法,用于保存或更新数据库中的记录。

在数据库没有这一条情况下或者就是想要新增一条

python 复制代码
car = Car(user='张三', plate_number='123ABC')
car.save()  # 保存到数据库

更新已有记录

当你修改一个模型实例的属性时,调用 save() 来保存修改:

python 复制代码
car = Car.objects.get(id=1)  # 获取某条记录
car.plate_number = '456DEF'  # 修改属性
car.save()  # 保存修改到数据库

查询

获取所有记录

python 复制代码
cars = Car.objects.all()  # 返回所有Car对象

根据条件过滤

python 复制代码
cars = Car.objects.filter(user='张三')  # 查询用户为张三的所有记录

获取单个记录

python 复制代码
car = Car.objects.get(id=1)  # 根据主键 id 查询

获取最新的一条记录

python 复制代码
latest_car = Car.objects.latest('id')  # 根据id排序,获取最新一条

删除

删除某条记录

python 复制代码
car = Car.objects.get(id=1)  # 获取记录
car.delete()  # 删除该记录

批量删除

python 复制代码
Car.objects.filter(user='张三').delete()  # 删除所有用户为张三的记录
相关推荐
小Tomkk3 分钟前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
qq_124987075328 分钟前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
倒流时光三十年1 小时前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
怣501 小时前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx2 小时前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
冰暮流星2 小时前
javascript之二重循环练习
开发语言·javascript·数据库
ggabb2 小时前
中文的精确与意境,从来都不是英文能比肩的
sqlite
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
玄同7652 小时前
Python 后端三剑客:FastAPI/Flask/Django 对比与 LLM 开发选型指南
人工智能·python·机器学习·自然语言处理·django·flask·fastapi