如何在Django中安全且完整的删除一个Model类(超详细!!!)

在Django中安全且完整的删除一个Model类(超详细!!!)

有时候我们在Django项目中定义一个模型类且已经迁移到数据库中,可能会考虑得不够周到,想把这一个模型类给删除掉重新写或是不想要这一个模型类了想直接把它删除掉,但是不正确、不完全的删除只会让你的Django项目和数据库越来越混乱,最后在开发的过程中老是会有莫名其妙的问题出现(作者以前就是会这样😂😂😂),所以,为了让大家少因为这种情况而出错,就写出了这一篇文章帮助大家,希望能对大家学习或工作的过程中有所帮助~👍👍👍

具体可以分为以下四个步骤:

1.先删除模型类代码,就是class xxx;

2.删除掉模型类再migrations文件夹中生成的对应的文件;

3.删除mysql数据库中migrations表的对应数据;

4.再删除数据库中模型类对应生成的数据表;

如果还不太明白的同学可以看如下具体操作👇👇👇

一、前置准备🐷

假设我现在新建了一个名为Book的Django项目,并创建了一个book_shop的app,先做相关配置工作。

首先,先将book_shop添加到setting.py文件中的INSTALLED_APPS中,如下所示:

INSTALLED_APPS = [
    "django.contrib.admin",
    "django.contrib.auth",
    "django.contrib.contenttypes",
    "django.contrib.sessions",
    "django.contrib.messages",
    "django.contrib.staticfiles",
    "book_shop",
]

而后,将django项目连接到名为book_db的数据库,如下所示:

DATABASES = {
    "default": {
        "ENGINE": "django.db.backends.mysql",
        "NAME": "book_db",
        "HOST": "localhost",
        "PORT": 3306,
        "USER": "root",
    }
}

接下来就是我们要讲的重点,在book_shop这个app中的model.py中,先定义了一个model类叫做Book,并设计相关的字段,如下

from django.db import models
from datetime import datetime

# Create your models here.


class Book(models.Model):
    book_name = models.CharField(max_length=50)               # 书本名
    book_author = models.CharField(max_length=30)             # 书本作者名
    book_description = models.TextField(help_text="书本介绍")  # 书本介绍
    create_at = models.DateTimeField(default=datetime.now)    # 书本创建时间
    update_at = models.DateTimeField(default=datetime.now)    # 书本修改时间

    class Meta:
        db_table = "Book_shop"  # 更改数据表名

而后运行命令,生产迁移文件,并迁移到数据库中,如下:

python manage.py makemigrations  # 生成迁移文件
python manage.py migrate  # 执行迁移到数据库

等待迁移结束,我们就可以在数据库中看到相关数据表和对应的字段

生成的数据表:

在这里插入图片描述

book_shop数据表中的字段:

在这里插入图片描述

二、安全的完整删除一个模型类🐷🐷

第🐷步:先删除模型类代码,也就是class Book

先将book_shop中的model.py文件中的Book模型代码全部给删除掉。

删除前:

在这里插入图片描述

删除后:

在这里插入图片描述

第🐷🐷步:删除掉模型类再migrations文件夹中生成的对应的文件

删除掉,book_shop中migrations生成的对应的迁移文件

在这里插入图片描述

第🐷🐷🐷步:删除mysql数据库中migrations表的对应数据

打开数据库,找到我们连接的book_db数据库下的django_migrations数据表,点开django_migrations数据表后把对应的book_shop这一行的数据删除掉。(为什么是book_shop呢?因为我们在定义模型类的时候给Book模型定义了一个别名,就是book_shop,可以回到前置准备中的model.py文件处的代码查看)

在这里插入图片描述

第🐷🐷🐷🐷步:删除数据库中模型类对应生成的数据表

到book_db数据库下生成的book_shop表,然后把它删除掉,就大功告成了!

在这里插入图片描述

而后我们又可以重新新建一个名为Book的模型类啦!希望这一篇文章对您有帮助,感谢您的观看!

如果有任何问题,欢迎在评论区留言噢~👀

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 好的,以下是一个简单的 Django Model 的例子: ```python from django.db import models class MyModel(models.Model): name = models.CharField(max_length=100) email = models.EmailField(max_length=100, unique=True) age = models.IntegerField(default=0) created_at = models.DateTimeField(auto_now_add=True) def __str__(self): return self.name ``` 这个 Model 定义了一个名为 `MyModel` 的数据模型,其包含四个字段: - `name` 字段:使用 `CharField` 型定义,最大长度为 100 个字符。 - `email` 字段:使用 `EmailField` 型定义,最大长度为 100 个字符,并设置为唯一值。 - `age` 字段:使用 `IntegerField` 型定义,设置默认值为 0。 - `created_at` 字段:使用 `DateTimeField` 型定义,并自动设置为当前间。 在这个 Model ,还定义了一个 `__str__` 方法,它将返回该对象的 `name` 属性的值。这个方法用于在 Django 管理界面和其他地方显示该对象的字符串表示形式。 ### 回答2: Django一个功能强大且易于使用Python Web框架,它提供了一种方便的方式来创建和管理数据库模型。下面是一个使用Django创建的简单模型的示例: ```python from django.db import models class User(models.Model): # 定义字段 username = models.CharField(max_length=50, unique=True) email = models.EmailField(unique=True) password = models.CharField(max_length=50) created_at = models.DateTimeField(auto_now_add=True) is_active = models.BooleanField(default=True) # 定义方法 def __str__(self): return self.username def is_admin(self): return self.is_superuser class Meta: db_table = 'users' ``` 上面的代码定义了一个名为User的模型,它继承自DjangoModel。模型定义了几个字段和一些方法: - username: CharField型,表示用户名,最大长度为50个字符,且必须是唯一的。 - email: EmailField型,表示电子邮件地址,必须是唯一的。 - password: CharField型,表示密码,最大长度为50个字符。 - created_at: DateTimeField型,表示创建间,会在对象首次保存自动添加。 - is_active: BooleanField型,表示用户是否激活,默认为True。 模型还定义了一个Meta,用来设置关于模型的元数据,比如数据库表名。在这个例子,我们将数据库表名设置为"users"。 模型还定义了两个方法:__str__用于返回对象的字符串表示,is_admin用于检查用户是否为管理员。 这只是一个简单的示例,实际应用,模型可能会包含更多字段和方法,以满足具体业务需求。编写Django模型,我们需要根据需求来设计字段和方法,以便能够有效地存储和操作相关数据。 ### 回答3: 在DjangoModel是用于定义数据结构的,通过对数据库表的操作实现对数据的增删改查。 下面是一个简单的Django Model示例: ```python from django.db import models class Book(models.Model): # 定义Book模型的属性 title = models.CharField(max_length=100) author = models.CharField(max_length=50) publish_date = models.DateField() price = models.DecimalField(max_digits=6, decimal_places=2) def __str__(self): return self.title ``` 上述代码定义了一个名为Book的模型,它包含了四个属性:title、author、publish_date和price。其,title和author是字符型字段,publish_date是日期字段,price是十进制字段。每个字段的使用都通过Django的`models`模块来定义。 在模型定义,还可以添加一些特殊的方法,例如上述代码的`__str__(self)`方法,用于返回模型的可读表示。这个方法在通过ORM获取Book对象会被自动调用,将Book对象转换为字符串的形式显示。 使用这个Model后,我们可以通过调用其API方法,进行对Book对象的操作,例如: ```python # 创建一个新书籍对象 book = Book.objects.create(title="Python入门教程", author="张三", publish_date="2022-01-01", price=29.99) # 查询书籍对象 books = Book.objects.all() for book in books: print(book.title, book.author) # 更新书籍对象属性 book.title = "Python实战教程" book.save() # 删除书籍对象 book.delete() ``` 通过以上代码,可以创建、查询、更新和删除Book对象。这个Model能够将书籍的相关信息存储到数据库,并提供了方便的API方法供开发者操作这些数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值