Django中级指南:理解并实现Django的模型和数据库迁移

Django 是一个极其强大的 Python Web 框架,它提供了许多工具和特性,能够帮助我们更快速、更便捷地构建 Web 应用。在本文中,我们将会关注 Django 中的模型(Models)和数据库迁移(Database Migrations)这两个核心概念。

一、理解 Django 模型

在 Django 中,模型是一种特殊的对象,它对应数据库中的一张表。每个模型都是一个 Python 类,它继承自 django.db.models.Model。模型的每个属性代表一个数据库字段。例如,我们在 polls 应用中创建一个名为 Question 的模型,它有两个字段:问题描述和发布日期:

python 复制代码
from django.db import models

class Question(models.Model):
    question_text = models.CharField(max_length=200)
    pub_date = models.DateTimeField('date published')

二、激活模型

创建完模型之后,我们需要告诉 Django 我们要在数据库中为这个模型创建一张表。首先,在 polls 应用的目录下找到 settings.py 文件,将 polls 应用添加到 INSTALLED_APPS 列表:

python 复制代码
INSTALLED_APPS = [
    ...
    'polls.apps.PollsConfig',
    ...
]

然后,运行以下命令让 Django 创建模型对应的数据库表:

bash 复制代码
python manage.py makemigrations polls

这个命令将为 Question 模型创建一个名为 0001_initial.py 的迁移文件。这个文件包含了 Django 用来创建数据库表的 Python 代码。

三、理解数据库迁移

数据库迁移是 Django 用来同步你的模型和数据库结构的方式。每当你修改了模型(如添加字段、删除模型等),你就需要生成一个迁移文件,然后运行这个迁移文件来应用你的修改。

你可以使用以下命令来查看 Django 计划执行哪些 SQL 命令:

bash 复制代码
python manage.py sqlmigrate polls 0001

你可以使用以下命令来应用迁移:

bash 复制代码
python manage.py migrate

这个命令将执行所有尚未应用的迁移,将数据库结构与你的模型同步。

四、使用 Django 管理界面

一旦你的模型被 Django 管理界面识别,你就可以使用它来创建、修改和删除记录。首先,打开 polls/admin.py 文件,将 Question 模型注册到 admin 界面:

python 复制代码
from django.contrib import admin

from .models import Question

admin.site.register(Question)

然后,启动服务器并访问 http://localhost:8000/admin/,你就可以看到 Question 模型并进行操作了。

五、总结

在这篇文章中,我们学习了 Django 的模型和数据库迁移,以及如何在 Django 管理界面中操作模型。模型和数据库迁移是 Django 的核心组成部分,理解它们对于掌握 Django 非常重要。希望你能从这篇文章中受益,并继续探索 Django 的世界。

相关推荐
DolphinScheduler社区37 分钟前
白鲸开源WhaleStudio与崖山数据库管理系统YashanDB完成产品兼容互认证
数据库·开源·认证·崖山数据库·白鲸开源
阑梦清川44 分钟前
AI超级智能体项目教程(二)---后端项目初始化(设计knif4j接口文档的使用)
java·前端·数据库
hotlinhao44 分钟前
ThinkPHP6模型中多组条件逻辑或Or查询的使用
linux·服务器·数据库
jack xu11 小时前
高频面试题:如何保证数据库和es数据一致性
java·大数据·数据库·mysql·elasticsearch
Pocker_Spades_A1 小时前
金仓数据库征文-政务领域国产化数据库更替:金仓 KingbaseES 应用实践
数据库·政务·金仓数据库 2025 征文·数据库平替用金仓
XY.散人1 小时前
初识Redis · 哨兵机制
数据库·redis·缓存
__淡墨青衫__2 小时前
Django之旅:第七节--模版继承
数据库·django·sqlite
秃头佛爷2 小时前
常用SQL整理
数据库·sql
时序数据说2 小时前
时序数据库IoTDB与OpenTSDB的对比分析
大数据·数据库·时序数据库·iotdb·opentsdb
爱的叹息2 小时前
DeepSeek 大模型 + LlamaIndex + MySQL 数据库 + 知识文档 实现简单 RAG 系统
数据库·人工智能·mysql·langchain