django的增删改查,排序,分组等常用的ORM操作

Django 的 ORM(对象关系映射)提供了一种方便的方式来与数据库进行交互。

1. Django模型

复制代码
在 `myapp/models.py` 中定义一个示例模型:

```python
from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=100)
    age = models.IntegerField()
    city = models.CharField(max_length=100)

    def __str__(self):
        return self.name

运行迁移命令来创建数据库表:

bash 复制代码
python manage.py makemigrations
python manage.py migrate

2. 增 (Create)

创建单个对象
python 复制代码
from myapp.models import Person

# 创建并保存一个新对象
person = Person(name='Alice', age=25, city='New York')
person.save()
使用 create() 方法
python 复制代码
person = Person.objects.create(name='Bob', age=30, city='Los Angeles')

3. 查 (Read)

获取所有对象
python 复制代码
people = Person.objects.all()
for person in people:
    print(person.name, person.age, person.city)
获取单个对象
python 复制代码
person = Person.objects.get(id=1)
print(person.name, person.age, person.city)
使用过滤器
python 复制代码
# 获取所有年龄大于25的人
people = Person.objects.filter(age__gt=25)
for person in people:
    print(person.name, person.age, person.city)

4. 改 (Update)

更新单个对象
python 复制代码
person = Person.objects.get(id=1)
person.age = 26
person.save()
批量更新
python 复制代码
Person.objects.filter(city='New York').update(city='NYC')

5. 删 (Delete)

删除单个对象
python 复制代码
person = Person.objects.get(id=1)
person.delete()
批量删除
python 复制代码
Person.objects.filter(age__lt=20).delete()

6. 排序 (Ordering)

按单个字段排序
python 复制代码
people = Person.objects.all().order_by('age')
for person in people:
    print(person.name, person.age, person.city)
按多个字段排序
python 复制代码
people = Person.objects.all().order_by('city', '-age')
for person in people:
    print(person.name, person.age, person.city)

7. 分组 (Grouping)

Django ORM 不直接支持分组操作,但可以使用 annotateaggregate 方法来实现类似的功能。

使用 annotate 进行分组计数
python 复制代码
from django.db.models import Count

# 按城市分组并计数
city_counts = Person.objects.values('city').annotate(count=Count('id'))
for city_count in city_counts:
    print(city_count['city'], city_count['count'])
使用 aggregate 进行聚合操作
python 复制代码
from django.db.models import Avg, Max, Min

# 计算平均年龄
average_age = Person.objects.aggregate(Avg('age'))
print(average_age)  # 输出: {'age__avg': 27.5}

# 计算最大和最小年龄
age_stats = Person.objects.aggregate(Max('age'), Min('age'))
print(age_stats)  # 输出: {'age__max': 30, 'age__min': 25}

8. 复杂查询

Q 对象进行复杂查询
python 复制代码
from django.db.models import Q

# 获取年龄大于25或城市为'New York'的人
people = Person.objects.filter(Q(age__gt=25) | Q(city='New York'))
for person in people:
    print(person.name, person.age, person.city)
F 对象进行字段间比较
python 复制代码
from django.db.models import F

# 获取年龄大于等于城市长度的人
people = Person.objects.filter(age__gte=F('city__length'))
for person in people:
    print(person.name)
相关推荐
计算机徐师兄5 小时前
Python基于Django的创新实验室系统(附源码,文档说明)
python·django·创新实验室系统·python创新实验室系统·创新实验室·实验室系统·python实验室系统
源码之家6 小时前
计算机毕业设计:Python股票智能分析预测平台 Flask框架 数据分析 可视化 机器学习 随机森林 大数据(建议收藏)✅
python·机器学习·数据分析·django·flask·课程设计
B站_计算机毕业设计之家6 小时前
计算机毕业设计:Python股票投资辅助决策系统 django框架 request爬虫 协同过滤算法 数据分析 可视化 大数据 大模型(建议收藏)✅
爬虫·python·深度学习·算法·django·flask·课程设计
天天进步201520 小时前
Python全栈项目:从零构建基于 Django 的知识管理系统(KMS)
开发语言·python·django
刀法如飞1 天前
一款Python语言Django框架DDD脚手架,开箱即用
python·架构·django
源码之家1 天前
计算机毕业设计:Python股票交易管理可视化系统 Django框架 requests爬虫 数据分析 可视化 大数据 大模型(建议收藏)✅
爬虫·python·深度学习·信息可视化·数据分析·django·课程设计
一 乐1 天前
智慧社区|基于Python + Django智慧社区系统(源码+数据库+文档)
java·数据库·python·django·论文·毕设·智慧社区系统
源码之屋1 天前
计算机毕业设计:Python天天基金数据采集与智能分析平台 Django框架 数据分析 可视化 爬虫 大数据 大模型(建议收藏)✅
人工智能·爬虫·python·数据分析·django·flask·课程设计
源码之家1 天前
计算机毕业设计:Python基金股票数据分析与可视化平台 Django框架 数据分析 可视化 爬虫 大数据 大模型(建议收藏)✅
爬虫·python·信息可视化·数据分析·django·flask·课程设计
AC赳赳老秦2 天前
OpenClaw二次开发实战:编写专属办公自动化技能,适配个性化需求
linux·javascript·人工智能·python·django·测试用例·openclaw