Django模型与数据库表映射的两种方式

对于Django项目开发的相关笔记

1.models模型类自动生成数据库表

在Django框架中,可以通过手动编写模型类来自动生成数据库表。

这种方式适用于中小型项目,能够精确控制表结构。

简单的来说:通过编写代码来创建数据库

python 复制代码
from django.db import models

class User(models.Model):
    username = models.CharField(max_length=50, unique=True)
    email = models.EmailField(max_length=100, unique=True)
    password = models.CharField(max_length=100)
    created_at = models.DateTimeField(auto_now_add=True)

    class Meta:
        db_table = 'auth_user1'
        verbose_name = '用户'
        verbose_name_plural = '用户'
 

关键字段类型说明:

  • CharField: 字符串字段,需指定max_length
  • EmailField: 带有Email验证的字符串字段
  • DateTimeField: 日期时间字段,auto_now_add表示创建时自动设置时间
  • unique=True: 设置字段唯一约束

迁移命令:

bash 复制代码
python manage.py makemigrations

python manage.py migrate

如果仅仅需一个表的话,其他表删除

命令: python manage.py migrate mytest

2.根据表结构自动生成models模型类

反向工程:通过已经设计好的,现存的数据库表生成对应代码到应用文件models.py里面

简单的来说:通过数据库表来创建代码

生成命令:

bash 复制代码
python manage.py inspectdb  --database default auth_user1 > app/models.py
 

> 覆盖写入

>> 追加写入,带from语句,需要删除

ps:obsidain修改代码块颜色

https://forum-zh.obsidian.md/t/topic/40251/3

相关推荐
玄斎26 分钟前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
小鸡吃米…34 分钟前
Python 列表
开发语言·python
编织幻境的妖38 分钟前
SQL查询连续登录用户方法详解
java·数据库·sql
编程小Y1 小时前
MySQL 与 MCP 集成全解析(核心原理 + 实战步骤 + 应用场景)
数据库·mysql·adb
星依网络1 小时前
yolov5实现游戏图像识别与后续辅助功能
python·开源·游戏程序·骨骼绑定
大佐不会说日语~2 小时前
Spring AI Alibaba 的 ChatClient 工具注册与 Function Calling 实践
人工智能·spring boot·python·spring·封装·spring ai
零度@2 小时前
SQL 调优全解:从 20 秒到 200 ms 的 6 步实战笔记(附脚本)
数据库·笔记·sql
Miss_Chenzr2 小时前
Springboot优卖电商系统s7zmj(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
2501_921649492 小时前
如何获取美股实时行情:Python 量化交易指南
开发语言·后端·python·websocket·金融
qq_448011162 小时前
python HTTP请求同时返回为JSON的异常处理
python·http·json