django2.0-系列- Django2.2报错 AttributeError: ‘str‘ object has no attribute ‘decode‘ ~ 开启django2

django2.0 :on_delete 

说明:on_delete 有 CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET() 五个可选择的值。原文:Django Admin 管理工具 | 菜鸟教程

  •  CASCADE:此值设置,是级联删除。
  •  PROTECT:此值设置,是会报完整性错误。
  •  SET_NULL:此值设置,会把外键设置为 null,前提是允许为 null。
  •  SET_DEFAULT:此值设置,会把设置为外键的默认值。
  •  SET():此值设置,会调用外面的值,可以是一个函数。一般情况下使用 CASCADE 就可以了。

开始django2.0的学习,入门文章推荐:

Django 2.0.3 使用笔记 - BlackMatrix - 博客园运行环境: Python 3.5.2 Django 2.0.3 Django Admin中model显示为中文 定义model时,定义一个Meta对象,设置需要显示的中文名称。verbose_namehttps://www.cnblogs.com/blackmatrix/p/8549365.html

Django2.2报错 AttributeError: 'str' object has no attribute 'decode'

准备将 Django 连接到 MySQL,在命令行输入命令 python manage.py makemigrations 后报错: AttributeError: 'str' object has no attribute 'decode'
出现这个错误之后可以根据错误提示找到文件位置,打开 operations.py 文件,找到以下代码:

def last_executed_query(self, cursor, sql, params):
    # With MySQLdb, cursor objects have an (undocumented) "_executed"
    # attribute where the exact query sent to the database is saved.
    # See MySQLdb/cursors.py in the source distribution.
    query = getattr(cursor, '_executed', None)
    if query is not None:
        query = query.decode(errors='replace')
    return query

根据错误信息提示,说明 if 语句执行时出错, query 是 str 类型,而 decode() 是用来将 bytes 转换成 string 类型用的,(关于Python编码点这里),由于 query 不需要解码,所以直接将 if 语句注释掉就可以了

def last_executed_query(self, cursor, sql, params):
    # With MySQLdb, cursor objects have an (undocumented) "_executed"
    # attribute where the exact query sent to the database is saved.
    # See MySQLdb/cursors.py in the source distribution.
    query = getattr(cursor, '_executed', None)
    # if query is not None:
    #     query = query.decode(errors='replace')
    return query
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值