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

在创建模型的时候,在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 模型

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值