• django models实际操作中遇到的一些问题


    问题1.将主键id改成自动生成的python3 manage.py migrate时报下面的错误

    django.db.utils.InternalError: (1091, "Can't DROP 'id'; check that column/key exists")
     
    我猜测是因为我改了两个表的主键,其中A表主键是B表的外键,删除会有问题
     
    解决方法:
    1.删除app下migrations文件夹中000开头的记录文件
    2.删掉app对应的数据库drop database 数据库名;
    4.重新建立刚刚删除的数据库create database 数据库名;
    3.然后重新执行修改数据库的命令:
      python3 manage.py makemigrations
      python3 manage.py migrate
     

    问题2:django向数据库中添加中文时报错

    django.db.utils.InternalError: (1366, "Incorrect string value: '\xE7\x99\xBB\xE5\xBD\x95...' for column 'chinessname' at row 1")
     
    解决方法:创建数据库的时候设置编码格式
     CREATE DATABASE 数据库名 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
     

    问题3:增加主键没生效,每次都只是执行了update

    django的models通过AutoField设置自增主键后,没有递增,代码如下
    class elements(models.Model):
        elementid=models.AutoField(primary_key=True,default=1)
        pageid=models.ForeignKey(page)
     
    解决方法:去掉default=1
    如果有default,它实现的是update,只有去掉default,才执行insert
     

    问题4:models存储包含外键的数据时,报错

    ValueError: Cannot assign "'12'": "elements.pageid" must be a "page" instance.
     
    models的数据结构:
    class page(models.Model):
        pageid=models.AutoField(primary_key=True)
        
    class elements(models.Model):
        elementid=models.AutoField(primary_key=True)
        pageid=models.ForeignKey(page)
     
    解决方法:
    page对象的paged是elements的外键,在使用save时,需要传递一个page对象实例
    elements(pageid=page.objects.get(pageid=xxx).save()
     
  • 相关阅读:
    HDU1316 fib+高精度
    HDU1868
    HDU2586 LCA
    HDU1113 字符串处理
    HDU1115 几何+多边形重心
    HDU1124
    HDU1110 几何
    HDU1103
    HDU2670 DP
    linux 下查看机器是cpu是几核的
  • 原文地址:https://www.cnblogs.com/meitian/p/6412265.html
Copyright © 2020-2023  润新知