django 删除数据库表后重新同步
来源:互联网 发布:查询linux ipv6 arp 编辑:程序博客网 时间:2024/06/05 14:43
由于项目需要,最近在用基于Python语言的一个后端框架Django开发web应用。不得不说,Django继承了Python的简洁性,用它来开发web应用简单清爽,不同于从前的SSH框架,需要单独配置每个框架,还需要通过配置将各个框架集合起来,Django就集成了SSH三个框架的功能,只需要配置好这一个框架,整个后端开发流程全部可以完成,并且配置过程简单易学,这就大大降低了程序员的使用复杂度,可以将更多的精力集中于写出好的代码,而不是纠结于工具的使用。
闲言少叙,现在就来说一说我遇到的问题和解决方案。
我们都知道Django提供了ORM的功能,可以通过操作代码中的类直接创建数据库表以及进行增删改查。但是在开发过程中,由于数据库表的重新设计,需要删除原表,并通过Django的ORM功能重新同步表。
同步命令如下:
python manage.py makemigrations
python manage.py migrate
但是在我输入命令之后报错了:
提示说我新增的字段没有默认值(我对数据库表的修改就是增加了一个字段),然后我去百度,在stackoverflow上找到了答案,在该字段后增加一个默认值即可。但是明显这个答案没有找到我遇到问题的真正原因,因为这样做第一条命令成功执行,但是到第二条时就直接报错。然后我又去百度,有人建议看一下框架自动生成的initial文件,该文件在当前app下的migrations目录下,打开后发现该文件内容和原表对应,也就是并没有更新,问题可能就在这了。于是我按照建议删除了这个文件重新生成。
删除文件之后重新执行命令,这次确实生成了新的initial文件,内容也已经更新,但是执行第二条命令时还是出了问题,查看数据库,空空如也,没有产生新表。崩溃。
然后又去百度,找相关问题看,看到另外一条命令:
python manage.py sqlmigrate your_app_name 0001
把your_app_name换成自己的app名字即可看到框架自动生成的创建表sql语句,于是我就这样看到了sql语句。我直接在数据库中执行了该句sql命令手动创建了表,再启动应用,可以正常启动,问题解决。
虽然这个方法有些取巧吧,似乎还是没有解释问题的症结所在,但好在很实用地解决了问题。
- django 删除数据库表后重新同步
- Django 修改model后同步修改数据库
- django 将删除的表重新生成
- 使用pgadmin3操作数据库 简介,误删数据表格后用Django重新生成表
- django models 增加字段(或新表)后如何同步到数据库
- django修改models.py后同步更新到数据库
- django 增加字段后同步不上数据库
- 数据库goldgate重新同步
- Django mysql 删除表后再次创建
- Django同步数据库不能创建app表
- django 数据库同步
- django 同步数据库
- Django 1.10 数据库同步
- Django同步数据库(Mysql)
- python Django 同步mysql数据库
- django 1.9 同步数据库bug
- Django项目同步数据库步骤
- django(python manage.py imgrate)同步数据库出错后的解决办法
- 说说Java里的equals(上)
- 【大数据 hadoop】大数据框架Hadoop主要模块介绍
- 安卓中关于Handler机制的浅谈
- 插件化基础之Java世界
- Visual Assist X中文注释为提醒注释错误
- django 删除数据库表后重新同步
- 获取select中选中option的值
- 【Java并发】- ScheduledThreadPoolExecutor, ScheduledExecutorService使用
- mysql高级 视图,触发器,存储过程
- WinScp、Scrt的使用和相关SSH、SFTP概念解析
- VtkPolyData的镜像操作
- Linux串口驱动程序(3)-串口打开分析
- 物联网学习博客和文章存档
- mysql完整备份时过滤掉某些库暨xargs的用法