Django - 把自己给坑了的 *** 作 - 模型建好,也迁移了,但数据库内却没帮我建表 - managed=False

Django - 把自己给坑了的 *** 作 - 模型建好,也迁移了,但数据库内却没帮我建表 - managed=False,第1张

在创建模型的时候,在class Meta 添加了一个参数 managed=False,那么恭喜你,成功入坑,它的本意是想让开发者自己创建id主键,不需要Django去帮你管理,如数据库表的创建等等,所以如果你铁了心想要自己自食其力的话,我没话说,请自便。
当然也不是说这个参数没好处,其实因为Django模型的出现,开发者利用ORM框架开发数据库表等 *** 作,的确是提高了挺多效率的。

使用 ORM 的好处:

1、 提高开发效率。
2.、 不同数据库可以平滑切换。

使用 ORM 的缺点:

1、 ORM 代码转换为 SQL 语句时,需要花费一定的时间,执行效率会有所降低。
2、长期写 ORM 代码,会降低编写 SQL 语句的能力。

ORM 解析过程:

1、ORM 会将 Python 代码转成为 SQL 语句。
2、SQL 语句通过 pymysql 传送到数据库服务端。
3、在数据库中执行 SQL 语句并将结果返回。

言归正传,问题的解决方法如下:

直接都删了,或都注释掉,还有如果之前在模型内建了如下id,也给注释或删了。

id = models.AutoField(primary_key=True)

接着,把迁移文件都给删了,这里我是使用 Pycharm - delete - OK

有两种方法,一种是使用Pycharm开发工具运行manage.py文件,一种是在虚拟环境内运行manage.py文件。

1、Pycharm开发工具


在新出现的命令行终端输入命令:

python manage.py makemigrations (yourappname)
python manage.py migrate (yourappname)

2、使用虚拟环境下的终端界面输入如下命令:

python manage.py makemigrations (yourappname)
python manage.py migrate (yourappname)

eg:

python manage.py makemigrations testapp
python manage.py migrate testapp

参考链接:

1. Django 可以创建迁移文件,但数据库里不创建新表(通过命令生成model的朋友看过来)

2. 成功解决了django迁移时不能创建相应表或字段的问题

3. Django 模型

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/922640.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-16
下一篇2022-05-16

发表评论

登录后才能评论

评论列表(0条)

    保存