这里先介绍第一个坑:
这是由于在python2.7 ,django1.11 的时候,django框架不会对数据库的表名做唯一性的校验。但是对于新的框架 django3.2 而言,它是会自动对数据库中的所有表的表名做唯一性校验的。
根据报错,找到相应的报错位置:
这里可以看出,有 db_table 重名了,因此,这里就2个解决方案,要么改表名(用户长期使用的生产环境,你改一个试试),要么,就是让它忽略对表名的唯一性检测。
只需要加一行代码即可。
如下:
这样服务就可以正常启动了。注意,这里有2个表重名了,我们只需要给一个表中加这行代码即可。
第二个坑:
第二个坑其实还是与MEAT相关,数据库中,对于关联表的查询往往是这么写的:
related_model = related_model._meta.get_field(related_name).rel.to
如图:
但是,当django在升级以后,这样的写法,就作废了。所以,在新的框架里跑旧的代码就会出现错误。
新的写法是:
related_model = related_model._meta.get_field(related_name).remote_field.model
如图:
这样,就不会引起查询错误了。