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(一个自动设置为当前时间的日期时间字段)。

2. 迁移(Migrations)

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

bash
复制
# 创建迁移文件
python manage.py makemigrations

# 应用迁移文件
python manage.py migrate


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

3. 查询数据库

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]

4. 创建和更新对象

你可以使用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()

5. 删除对象

你也可以使用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,你可以专注于实现业务逻辑,而无需过多关注底层数据库的细节。

相关推荐

  1. sqlite简单增删

    2024-04-05 05:36:03       45 阅读
  2. tp6 mongodb简单增删

    2024-04-05 05:36:03       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-05 05:36:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-05 05:36:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-05 05:36:03       82 阅读
  4. Python语言-面向对象

    2024-04-05 05:36:03       91 阅读

热门阅读

  1. 十九、Rust Tcp Rpc 示例

    2024-04-05 05:36:03       38 阅读
  2. C# 系统学习(异步编程)

    2024-04-05 05:36:03       39 阅读
  3. 数据结构——顺序表实现通讯录

    2024-04-05 05:36:03       31 阅读
  4. AI与技术美术(TechArt)

    2024-04-05 05:36:03       32 阅读
  5. 什么是机器学习?

    2024-04-05 05:36:03       32 阅读
  6. 机器学习之常用的回归预测模型

    2024-04-05 05:36:03       34 阅读
  7. 【Trick】机器学习技术路线

    2024-04-05 05:36:03       37 阅读
  8. 课时85:流程控制_函数基础_基础知识

    2024-04-05 05:36:03       34 阅读