前言:今天也是充满bug的一天,脸上笑嘻嘻。。。。(继续,讲文明,懂礼貌)

1,问题描述,models中的字段设置的是浮点型,但是输出的结果总是int()类型

models

average_score = models.FloatField(verbose_name='平均分')

2、查找原因,首先进入数据库

 mysql  #进入数据库

 show databases;    

 use mydata;  进入你的数据库

 des knowledge_knowledgebase; 查看相应字段

然后就会发现,是的,现在average_acore的字段是int()没错的

3、这时候你就会说同步一下数据库不就好了,然而并不是我太傻太天真。

python manage.py makemigrations  报错

django.db.migrations.exceptions.InconsistentMigrationHistory: Migration admin.0001_initial is applied before its dependency users.0001_initial on database 'default'

原因:大概原因是因为admin的模型依赖了之前默认的user模型吧

4、最终解决方案

首先将migrations下的数据删除,然后在migrate肯定是可以的,但是测试需要我必须保留其中的数据,解决方案如下。

a、首先建一个新表

1、drop database mydata2;

2、 create database mydata2 character set utf8 collate utf8_bin

b、在setting中指向该数据库

c、数据reset

sh reset.sh  该文件内容(该内容就是直接删除migrations目录下的数据,重新编译)

 #!/usr/bin/env bash
rm -rf user_center/mi*
rm -rf alert_center/mi*
rm -rf count_center/mi*
rm -rf cmdb_center/mi*
rm -rf work_center/mi*
rm -rf knowledge/mi*
rm -rf call_center/mi*
rm -rf report_center/mi*
python manage.py makemigrations --empty work_center
python manage.py makemigrations --empty cmdb_center
python manage.py makemigrations --empty call_center
python manage.py makemigrations --empty report_center
python manage.py makemigrations --empty user_center
python manage.py makemigrations --empty count_center
python manage.py makemigrations --empty alert_center
python manage.py makemigrations --empty knowledge
python manage.py makemigrations
python manage.py migrate
python manage.py createsuperuser

d、将原数据库mydata的数据导出

  mysqldump -uroot  mydata > mcenter2.sql

e、进入mysql环境

 show databases; 

 use mydata2;  #新表

 desc knowledge_knowledgebase;

 source /home/mcenter_backstage/mcenter_backstage/mcenter2.sql; #将原表的数据同步到新表

 alter table knowledge_knowledgebase modify column average_score float(5,2); #更改字段的数据类型

 alter table knowledge_knowledgebase modify column create_time datetime;  #更改字段的数据类型

总结:当数据库中包含数据的时候,无法migrate成功,所以只能更改数据库中的相应字段,这个办法算是比较笨了。后续找到解决办法会更新。

Django 无法同步数据库model相应字段问题的更多相关文章

  1. Django入门:操作数据库(Model)

    Django-Model操作数据库(增删改查.连表结构) 一.数据库操作 1.创建model表         基本结构 1 2 3 4 5 6 from django.db import model ...

  2. django无法同步数据库 Error loading MySQLdb module: No module named ‘MySQLdb‘

    最近在学习Python,打算先看两个在线教程,再在github上找几个开源的项目练习一下,在学到“被解放的姜戈”时遇到django同步数据库时无法执行的错误,记录一下. 错误现象: 执行python ...

  3. django 修改字段后,同步数据库,失败:django.db.utils.InternalError: (1054, "Unknown column 'api_config.project_id_id' in 'field list'")

    问题原因是,修改字段后,同步失败了,然后执行查询的时候,就会提示这个错误,这个字段没有 最暴力的方法可以直接在数据库中修改字段,但是修改后,models没同步,可能会存在问题,因此开始我的百度之旅(这 ...

  4. 自动化监控系统(二)连接数据库,创建app,添加model,同步数据库

    数据库我使用:mysql5.7 程序连接数据库的模块:pymysql 一.创建数据库: dbname:automatedmonitor 二.使用pip安装pymysql,这里我直接在pycharm上安 ...

  5. Django数据库设计中字段为空的方式

    今天在做数据库设计的时候,设计了如下User表,其中我把email和phone字段设置为允许为空: class User(models.Model): username = models.CharFi ...

  6. Django中的Model(字段)

    Model Django中的model是用来操作数据库的,Model是一个ORM框架,我们只需要关心model的操作,而不需要关心到底是哪一种数据库. 一.基本知识: 数据库引擎: Django中自带 ...

  7. django model常用字段类型

    摘自 http://www.cnblogs.com/wt869054461/p/4014271.html V=models.AutoField(**options) #int:在Django代码内是自 ...

  8. Django---ORM的常用字段和自定义字段,DjangoORM字段与数据库类型对应,字段参数和Meta的参数,Django的admin操作,13中orm操作方法,单标的双下方法

    Django---ORM的常用字段和自定义字段,DjangoORM字段与数据库类型对应,字段参数和Meta的参数,Django的admin操作,13中orm操作方法,单标的双下方法 一丶ORM常用字段 ...

  9. Django 同步数据库的时候app中的models的表没有成功创建

    出现  no  changes detected python3 manage.py makemigrations --empty blog # blog就是你的app名字,此处要写成自己的app名字 ...

随机推荐

  1. zabbix4.4.2安装部署

    1.下载阿里的源,执行 wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo 2 ...

  2. webpack 之搭建本地服务器

    搭建本地服务器 webpack提供了一个可选的本地开发服务器,这个本地服务器基于node.js搭建,内部使用express框架,可以实现 我们想要的让浏览器自动刷新显示我们修改后的结果 不过它是一个单 ...

  3. 浅谈C#委托的用法-delegate

    2018年11月7日     小雨 一.委托的概念 委托和类一样是一种用户自定义类型,它存储的就是一系列具有相同签名和返回类型的方法的地址,调用委托的时候,它所包含的所有方法都会被执行. 借用百度上的 ...

  4. 虚拟磁盘VHD文件压缩方法

    问题描述 因工作需要在Mac上跑了一个VirtualBox虚拟win7,使用对win系统友好的vhd格式作为虚拟硬盘.经过一段时间使用发现vhd占用空间远大于虚拟磁盘使用量,想办法减减肥才行. 步骤整 ...

  5. php中构建树状图

    /** * 指定根层级的树状图 * @param array $list 初始数组 * @param int $root 最上级一条数据的id * @param string $pk 每一条数据的id ...

  6. 继 “多闪”后“飞聊”再被diss?其实社交还能这么玩

    近日头条低调上线了新的社交APP——飞聊,目前在AppStore社交排行榜第7位.但很多人使用了之后都觉得新产品的各个功能都让人想起其他的产品.兴趣小组让人想到豆瓣的兴趣小组,生活动态让人想到微博动态 ...

  7. Django 初试水(一)

    2020年注定是一个不平凡的一年!坚持就是胜利,一起加油! 至于为什么使用 Django,也不想说太多.个人喜欢,这里不做介绍.直接进入主题.show me the code!!! python 的环 ...

  8. 怎么解析后台返回数据中\r\n换行

      给div添加css样式, white-space: pre-wrap; 即可   文章来源:刘俊涛的博客 欢迎关注公众号.留言.评论,一起学习. _________________________ ...

  9. linq和扩展方法

    c#的扩展方法 1.必须是在一个非嵌套.非泛型的静态类中的静态方法 2.至少一个参数,第一个参数附加this,不能有其他修饰符如out.ref 3.第一个参数不能是指针类型 上面例子是自定义的一个扩展 ...

  10. C语言-const和volatile深度分析

    1.const只读变量 const修饰的变量是只读的.本质还是变量 const修饰的局部变量在栈上分配空间 const修饰的全局变量在全局数据区分配空间 const只在编译期有用,在运行期无用 con ...