django 数据库表生成models.py文件

http://djangobook.py3k.cn/chapter16/


python manage.py inspectdb > channel_flux/models.py


与遗留数据库整合 转:http://djangobook.py3k.cn/chapter16/
Django的数据库层从Python代码生成SQL schemas—但是对于遗留数据库,你已经拥有SQL schemas,这种情况下你需要为你已经存在的数据库表写模型(由于性能的原因,Django的数据库层不支持通过运行时自省数据库的不工作的对象-关系映射,为了使用数据库API,你需要写模型代码),幸运的是,Django带有通过阅读你的数据库表规划来生成模型代码的辅助工具该辅助工具称为manage.py inspectdb
使用 inspectdb
The inspectdb 工具内省检查你的配置文件(setting file)指向的数据库,针对你的每一个表生成一个Django model的表现,然后将这些Python model的代码显示在系统的标准输出里面。
下面是一个从头开始的针对一个典型的遗留数据库的整合过程
通过运行django-admin.py startproject mysite (这里 mysite 是你的项目的名字)建立一个Django项目。好的,那我们在这个例子中就用这个 mysite 作为项目的名字。
编辑项目中的配置文件, mysite/settings.py ,告诉Django你的数据库连接参数和数据库名。具体的说,要提供 DATABASE_NAME , DATABASE_ENGINE , DATABASE_USER , DATABASE_PASSWORD , DATABASE_HOST , 和 DATABASE_PORT 这些配置信息. (注意,这里面有些配置项是可选的,更多信息参考第五章)
通过运行 pythonmysite/manage.pystartappmyapp (这里 myapp 是你的应用的名字)创建一个Django应用.那么,我们就以 myapp 做为这个应用的名字.
运行命令 pythonmysite/manage.pyinspectdb . 这将在 DATABASE_NAME 数据库中检查所有的表和打印出为每张表生成的model class. 看一看输出结果想一下 inspectdb 能做些什么.
将标准shell的输出重定向,保存输出到你的应用的 models.py 文件里:
python mysite/manage.py inspectdb > mysite/myapp/models.py
编辑 mysite/myapp/models.py 文件以清理生成的 models 以及一些必要的定制化。下一个章节对此有些好的建议。 清理生成的Models
如你可能会预料到的,数据库自省不是完美的,你需要对产生的模型代码做些许清理。这里提醒一点关于处理生成 models 的要点:
数据库的每一个表都会被转化为一个model类 (也就是说,数据库的表和model 的类之间做一对一的映射)。这意味着你需要为多对多连接的表,重构其models 为 ManyToManyField 的对象。
所生成的每一个model中的每个字段都拥有自己的属性,包括id主键字段。但是,请注意,如果某个model没有主键的话,那么Django会自动为其增加一个Id主键字段。这样一来,你也许希望使用如下代码来对任意行执行删除操作:
id = models.IntegerField(primary_key=True)
这样做并不是仅仅因为这些行是冗余的,而且如果当你的应用需要向这些表中增加新记录时,这些行会导致某些问题。而inspectdb命令并不能检测出一个字段是否自增长的,因此必要的时候,你必须将他们修改为AutoField.
每一个字段类型,如CharField、DateField, 是通过查找数据库列类型如VARCHAR,DATE来确定的。如果inspectdb无法对某个model字段类型根据数据库列类型进行映射,那么它会使用TextField字段进行代替,并且会在所生成model字段后面加入Python注释“该字段类型是猜的”。因此,请特别注意这一点,并且在必要的时候相应的修改这些字段类型。
如果你的数据库中的某个字段在Django中找不到合适的对应物,你可以放心的略过它,因为Django层并没有要求必须包含你的表中的每一个字段。
如果数据库中某个列的名字是Python的保留字,比如pass、class或者for等,inspectdb会在每个属性名后附加上_field,并将db_column属性设置为真实的字段名,比如pass,class或者for等。
例如,某张表中包含一个INT类型的列,其列名为for,那么所生成的model将会包含如下所示的一个字段:
for_field = models.IntegerField(db_column='for')
inspectdb 会在该字段后加注 ‘字段重命名,因为它是一个Python保留字’ 。
如果数据库中某张表引用了其他表(正如大多数数据库系统所做的那样),你需要适当的修改所生成model的顺序,以使得这种引用能够正确映射。例如,model Book拥有一个针对于model Author的外键,那么后者应该先于前者被定义。如果你需要为一个还没有被定义的model创建一个关系,那么你可以使用该model的名字,而不是model对象本身。
对于PostgreSQL,MySQL和SQLite数据库系统,inspectdb能够自动检测出主键关系。也就是说,它会在合适的位置插入primary_key=True。而对于其他数据库系统,你必须为每一个model中至少一个字段插入这样的语句,因为Django的model要求必须拥有一个primary_key=True的字段。

你可能感兴趣的:(django)