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

相关推荐
智数研析社2 小时前
9120 部 TMDb 高分电影数据集 | 7 列全维度指标 (评分 / 热度 / 剧情)+API 权威源 | 电影趋势分析 / 推荐系统 / NLP 建模用
大数据·人工智能·python·深度学习·数据分析·数据集·数据清洗
扯淡的闲人2 小时前
多语言编码Agent解决方案(5)-IntelliJ插件实现
开发语言·python
moxiaoran57532 小时前
Flask学习笔记(一)
后端·python·flask
寻星探路2 小时前
数据库造神计划第六天---增删改查(CRUD)(2)
java·大数据·数据库
秋氘渔3 小时前
迭代器和生成器的区别与联系
python·迭代器·生成器·可迭代对象
Gu_shiwww3 小时前
数据结构8——双向链表
c语言·数据结构·python·链表·小白初步
盖世英雄酱581363 小时前
Read timed out问题 排查
java·数据库·后端
云动雨颤4 小时前
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
数据库·spring boot·tomcat
Dxy12393102164 小时前
python把文件从一个文件复制到另一个文件夹
开发语言·python