Django 数据库添加字段

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django 数据库添加字段相关的知识,希望对你有一定的参考价值。

在Django book的第十章讲到数据库添加字段的问题:
使用的技巧是利用Django不关心表里是否包含model里所没有的列的特性。 策略就是现在数据库里加入字段,然后同步Django的模型以包含新字段
然后后面就是一大段方法。
1.首先,进入开发环境(也就是说,不是在发布环境里):在你的模型里添加字段。

2.运行 manage.py sqlall [yourapp] 来测试模型新的 CREATE TABLE 语句。 注意为新字段的列定义。

3.开启你的数据库的交互命令界面(比如, psql 或mysql , 或者可以使用 manage.py dbshell )。 执行ALTER TABLE 语句来添加新列。

4.使用Python的manage.py shell,通过导入模型和选中表单(例如, MyModel.objects.all()[:5] )来验证新的字段是否被正确的添加 ,如果一切顺利,所有的语句都不会报错。

然后在你的产品服务器上再实施一遍这些步骤。

1.启动数据库的交互界面。

2.执行在开发环境步骤中,第三步的ALTER TABLE语句。

3.将新的字段加入到模型中。 如果你使用了某种版本控制工具,并且在第一步中,已经提交了你在开发环境上的修改,现在,可以在生产环境中更新你的代码了(例如,如果你使用Subversion,执行svn update。

4.重新启动Web server,使修改生效。

我的理解就是,先在数据库里添加字段,然后再修改模型代码,那这是否意味着,我可以直接利用数据库的管理工具直接添加字段,然后再直接修改模型代码呢?(上面的方法也太啰嗦了)

你说对了,假设你用数据库管理工具的话,你要先选择你工程所对应的数据库,比如mysql,直接用控制台操作的话,你需要先执行use yourdb,而用manage.py dbshell会自动链接到你用的数据库,省了输入用户名密码和use yourdb的过程。 参考技术A Django默认的ORM做的算是完善了,建议你直接在模型中操作,不要直接操作表结构,这样容易导致问题发生~

以上是关于Django 数据库添加字段的主要内容,如果未能解决你的问题,请参考以下文章

使用 django 动态添加输入字段并将数据保存到数据库

django 手动将模型字段添加到 postgres 数据库

如何使用 Django Rest Framework 向 ManyToMany 字段添加数据?

如何在 Django 中向模型添加临时字段?

使用注册表单添加到自定义用户字段(django)

Django:如何根据来自行的数据和来自另一个模型的数据将聚合字段添加到查询集中?