python测试开发django-72.删除表后如何重新生成表
2024-10-20 06:54:49
前言
在使用ORM建表的时候,由于需要对数据库表的重新设计,需要删除原表,并通过Django的ORM功能重新同步表。
删除表之后,发现用 makemigrations 和 migrate 无法生成新的表了。
遇到问题
当我新建一个 Model ,同步完数据库后,再修改里面的字段名称,发现无法同步到数据库,于是就把数据库里面的整张表删除了。
结果再同步数据库就无法生成新的表了,就算删除 migrations 目录下的0001_initial.py文件也一样。
# 新建了一个PersonIn类,继承自models.Model,
class PersonIn(models.Model):
uid = models.IntegerField(primary_key=True)
name = models.CharField(max_length=30)
agex = models.IntegerField()
删除 migrations 目录下的0001_initial.py文件
执行 makemigrations 和 migrate 无法生成新的表了
D:\soft\MyDjango>python manage.py makemigrations
Migrations for 'yoyo':
yoyo\migrations\0001_initial.py
- Create model PersonIn
D:\soft\MyDjango>python manage.py migrate
Operations to perform:
Apply all migrations: admin, auth, contenttypes, sessions, yoyo
Running migrations:
No migrations to apply.
D:\soft\MyDjango>
结果没生成新的表
解决办法1
如果删除后,无法自动生成,首先想到的解决办法,可以先查询到建表的sql,自己去执行sql建表
python manage.py sqlmigrate your_app_name 0001
cmd执行上面的命令,your_app_name 换成自己的 app 名称
D:\soft\MyDjango>python manage.py sqlmigrate yoyo 0001
BEGIN;
--
-- Create model PersonIn
--
CREATE TABLE `yoyo_personin` (`uid` integer NOT NULL PRIMARY KEY, `name` varchar(30) NOT NULL, `agex` integer NOT NULL);
COMMIT;
于是得到建表的SQL,去数据库执行下就可以了
解决办法2
上面的办法只能从表面上解决问题,不能解决根本问题,根本的原因是因为在 django_migrations 表里面已经生成表记录了。
执行 SQL 删除app相关的记录
delete from django_migrations where app=' your_app_name'
执行完成后,再执行makemigrations 和 migrate就可以同步成功了
D:\soft\MyDjango>python manage.py makemigrations
No changes detected
D:\soft\MyDjango>python manage.py migrate
Operations to perform:
Apply all migrations: admin, auth, contenttypes, sessions, yoyo
Running migrations:
Applying yoyo.0001_initial... OK
看到 OK 说明成功了
最新文章
- JAVA内存管理之堆内存和栈内存
- CocoaPods 使用
- 【转载】谷歌酝酿将苹果Swift作为安卓APP主要开发语言
- ubifs扩展性分析
- CentOS6.5 安装Zookeeper集群
- ubuntu 添加源
- GIT之一 起步篇
- 【Python】 做一个简单的 http server
- C# 序列化和反序列
- phpword这个问题的产生中国扭曲
- UVa 699 落叶
- ArcGIS制图表达Representation-规则和几何效果
- 2013 QCon北京演讲:跨终端的WebKit渲染机制
- day 10函数二
- C# 实现登录并跳转界面
- js中图片上传,多次上传同一张不生效
- var/let/const区别何在??(转载)
- C++ allocator
- nodejs----初期学习笔记
- Prometheus 监控进程