Python Django ORM使用简单的增,删,改,查

Django ORM(对象关系映射)是Django框架中用于与数据库交互的一个核心组件。它提供了一种方便、直观的方式来定义、查询和操作数据库中的数据。

  1. 定义模型(Model)

首先,你需要通过定义模型来告诉Django你的数据应该如何存储在数据库中。每个模型都是Django中的一个Python类,继承自django.db.models.Model。

python

复制

from django.db import models

class MyModel(models.Model):

name = models.CharField(max_length=100)

description = models.TextField()

date_created = models.DateTimeField(auto_now_add=True)

在这个例子中,MyModel有三个字段:name(一个最大长度为100的字符串)、description(一个文本字段)和date_created(一个自动设置为当前时间的日期时间字段)。

  1. 迁移(Migrations)

定义模型之后,你需要创建迁移文件,并应用这些迁移来创建或修改数据库中的表。

bash

复制

创建迁移文件

python manage.py makemigrations

应用迁移文件

python manage.py migrate

makemigrations命令会检查你的模型与数据库中当前的表结构是否一致,并生成相应的迁移文件。migrate命令则会应用这些迁移,更新数据库结构。

  1. 查询数据库

Django ORM 提供了一套丰富的API来查询数据库。

python

复制

导入模型

from .models import MyModel

获取所有对象

all_objects = MyModel.objects.all()

根据条件过滤对象

filtered_objects = MyModel.objects.filter(name='example')

获取单个对象

single_object = MyModel.objects.get(id=1)

排除某些对象

excluded_objects = MyModel.objects.exclude(name__contains='test')

使用Q对象进行复杂查询

from django.db.models import Q

complex_filtered_objects = MyModel.objects.filter(Q(name='example') | Q(description__icontains='keyword'))

排序

sorted_objects = MyModel.objects.order_by('name')

限制返回数量

limited_objects = MyModel.objects.all()[:10]

  1. 创建和更新对象

你可以使用ORM来创建和更新数据库中的对象。

python

复制

创建一个新对象并保存

new_object = MyModel(name='New Example', description='This is a new example.')

new_object.save()

更新一个已存在的对象

existing_object = MyModel.objects.get(id=1)

existing_object.name = 'Updated Name'

existing_object.save()

  1. 删除对象

你也可以使用ORM来删除对象。

python

复制

删除一个对象

object_to_delete = MyModel.objects.get(id=1)

object_to_delete.delete()

删除所有匹配的对象

MyModel.objects.filter(name='example').delete()

Django ORM 还提供了其他高级功能,如聚合、注释、F表达式、事务管理等,这些功能可以帮助你处理更复杂的数据库操作。

总之,Django ORM 提供了一种简洁而强大的方式来与数据库交互,使得数据库操作变得简单而直观。通过使用Django ORM,你可以专注于实现业务逻辑,而无需过多关注底层数据库的细节。

相关推荐
凌叁儿2 小时前
使用模块中的`XPath`语法提取非结构化数据
windows·python·beautifulsoup·pip
xiaohanbao092 小时前
day11 python超参数调整
python·学习·机器学习·信息可视化·pandas
青苔猿猿2 小时前
(4)python中jupyter lab使用python虚拟环境
开发语言·python·jupyter·虚拟环境
yangshuo12812 小时前
家庭服务器IPV6搭建无限邮箱系统指南
运维·服务器·python
计算机徐师兄2 小时前
基于Python Flask的深度学习电影评论情感分析可视化系统(2.0升级版,附源码)
python·深度学习·flask·电影评论情感分析·电影评论情感分析可视化系统·python电影评论情感分析·python电影情感分析系统
囚~徒~3 小时前
django_rq
后端·python·django
神奇侠20243 小时前
基于tabula对pdf中的excel进行识别并转换成word(三)
python·docx·tabula
LIUDAN'S WORLD4 小时前
第五部分:进阶项目实战
图像处理·人工智能·python·opencv·计算机视觉·目标跟踪
禺垣4 小时前
GBDT算法原理及Python实现
人工智能·python·算法·机器学习·数据挖掘·集成学习
谷雪_6584 小时前
AIGC 落地实战:用 Stable Diffusion 打造企业级营销素材生成平台
python·stable diffusion·aigc