python/Django模型/数据库迁移/创建数据库表

1."数据库迁移"(Database Migration):

在Django框架中,数据库迁移是将你的模型(即定义在models.py文件中的数据库表结构)变更同步到数据库中的过程。这包括创建新表、修改现有表结构(如添加或删除字段)以及执行其他数据库结构变更。

2.流程:

  1. 定义模型 :在Django应用的models.py文件中定义或修改模型类。

  2. 生成迁移文件 :运行python manage.py makemigrations命令,Django会自动检测到模型的变化,并为这些变化创建一个新的迁移文件。这个文件包含了将模型变更应用到数据库所需的所有操作。

  3. 应用迁移 :运行python manage.py migrate命令,Django会应用所有未执行的迁移,更新数据库结构以匹配模型定义。

3.例子

在创建的应用(app)的models.py文件内编写。

python 复制代码
from django.db import models

# Create your models here.
class Sight(models.Model):
    """ 景点基础信息 """
    name = models.CharField('名称', max_length=64)
    desc = models.CharField('描述', max_length=256)
    main_img = models.ImageField('主图', upload_to='%Y%m/sight/', max_length=256)
    banner_img = models.ImageField('详情主图', upload_to='%Y%m/sight/', max_length=256)
    content = models.TextField('详细')
    score = models.FloatField('评分', default=5)
    min_price = models.FloatField('最低价格', default=0)
    province = models.CharField('省份', max_length=32)
    city = models.CharField('市区', max_length=32)
    area = models.CharField('区/县', max_length=32, null=True)
    town = models.CharField('乡镇', max_length=32, null=True)

    is_top = models.BooleanField('是否为精选景点', default=False)
    is_hot = models.BooleanField('是否为热门景点', default=False)

    is_valid = models.BooleanField('是否有效', default=True)
    created_at = models.DateTimeField('创建时间', auto_now_add=True)
    updated_at = models.DateTimeField('修改时间', auto_now=True)

    class Meta:
        db_table ='sight'
        ordering = ['-updated_at']

注意:

要使用这个模型,你需要确保你的Django项目已经配置好了数据库,并且你已经创建了相应的数据库表。

你可以通过以下命令来创建和应用迁移

python 复制代码
python manage.py makemigrations
python manage.py migrate
相关推荐
运维行者_3 小时前
企业无线网络监控的挑战与智能化演进趋势
大数据·运维·服务器·网络·数据库
hhzz3 小时前
基于监控视频的水位尺自动识别技术方案与实现
python·opencv·yolo·图像识别·cv
yongche_shi3 小时前
ragas官方文档中文版(五十)
开发语言·python·ai·ragas·如何评估和改进 rag 应用
国强_dev3 小时前
技术探讨:使用 stunnel 加密转发数据库连接时,如何获取客户端真实 IP?
数据库·网络协议·tcp/ip
@insist1233 小时前
系统规划与管理师-信息系统规划核心工作要点解析
数据库·软考·系统规划与管理师·软件水平考试·系统规划与管理工程师
超级数据查看器3 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
weixin_408099674 小时前
OCR批量识别图片方案:从手动处理到自动化API系统(Python/Java/PHP实战)
图像处理·python·ocr·文字识别·api调用·批量识别·石榴智能
数安3000天4 小时前
增量数据如何自动分类分级,避免目录“过期“?
大数据·数据库
AI行业学习4 小时前
Notepad++ 官方下载 + 完整安装 + 全套优化配置(2026最新)
开发语言·人工智能·python·前端框架·html·notepad++
南墙上的石头5 小时前
麒麟 V10 重装人大金仓 V8R6 踩坑实录(含 MySQL 兼容模式)
数据库·mysql