虽然 Django 很适合开发新应用,但也能用它集成旧数据库。Django 包含了一整套套件来尽可能自动处理类似的任务。
本文假设你有 Django 基础,基础内容由 教程 介绍。
你配置完 Django 后,你就能跟着此常规操作去集成旧数据库了。
Django comes with a utility called inspectdb
that can create models
by introspecting an existing database. You can view the output by running this
command:
$ python manage.py inspectdb
Save this as a file by using standard Unix output redirection:
$ python manage.py inspectdb > models.py
该功能仅是一个快捷方式,不是最佳的创建模型的方法。参考 inspectdb 文档
获取更多信息。
只要你整理完这些模型,就可以将文件重命名为 models.py
并将其放入持有应用的 Python 包中。随后,将应用添加至 INSTALLED_APPS
配置。
默认情况下, inspectdb
创建未托管的模型。也就是说,模型的 Meta
类中的 managed = False
告诉 Django 不要管理这些表的创建,修改和删除:
class Person(models.Model):
id = models.IntegerField(primary_key=True)
first_name = models.CharField(max_length=70)
class Meta:
managed = False
db_table = "CENSUS_PERSONS"
若你的确想要允许 Django 管理这些表格的生命周期,你需要将上面的 managed
选项的值改为 True
(或者删掉它,因为 True
是默认值)。
Next, run the migrate
command to install any extra needed database
records such as admin permissions and content types:
$ python manage.py migrate
这些是基本步骤——这样,你就能调整 Django 生成的模型,直到他们达到你的要求。试着通过 Django 数据库 API 访问数据,试着通过 Django 后台站点编辑数据,也可以直接编辑模型文件。
5月 12, 2023