前言

在使用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 说明成功了

最新文章

  1. JAVA内存管理之堆内存和栈内存
  2. CocoaPods 使用
  3. 【转载】谷歌酝酿将苹果Swift作为安卓APP主要开发语言
  4. ubifs扩展性分析
  5. CentOS6.5 安装Zookeeper集群
  6. ubuntu 添加源
  7. GIT之一 起步篇
  8. 【Python】 做一个简单的 http server
  9. C# 序列化和反序列
  10. phpword这个问题的产生中国扭曲
  11. UVa 699 落叶
  12. ArcGIS制图表达Representation-规则和几何效果
  13. 2013 QCon北京演讲:跨终端的WebKit渲染机制
  14. day 10函数二
  15. C# 实现登录并跳转界面
  16. js中图片上传,多次上传同一张不生效
  17. var/let/const区别何在??(转载)
  18. C++ allocator
  19. nodejs----初期学习笔记
  20. Prometheus 监控进程

热门文章

  1. CF1163E Magical Permutation(线性基,构造)
  2. 把 DataTable 输出到 excel 文件
  3. oracle--oracle18C环境配置(一)
  4. java-int数据的溢出
  5. Ubuntu 14.04 apt-get update失效解决(转)
  6. 初始socket模块和巧解粘包问题
  7. RICOH C4502彩色打印机取消双面打印功能
  8. django实战(三)--删除和批量删除
  9. 多项式 ln
  10. CentOS安装vsftpd FTP后修改默认21端口方法