如何从包含1000个表的数据库中检查db 1表

时间:2014-11-27 05:32:08

标签: django oracle inspectdb

我有一个包含1000个表格的模式,其中许多我不需要, 我怎样才能只检查我需要的那些表?

5 个答案:

答案 0 :(得分:9)

您可以生成单个表的模型,运行此命令

python manage.py inspectdb TableName > output.py

如果您想生成视图模型

,这也适用

答案 1 :(得分:6)

您可以在python控制台或* .py文件中执行此操作:

from django.core.management.commands.inspectdb import Command
from django.conf import settings
from your_project_dir.settings import DATABASES  #  replace `your_project_dir`

settings.configure()
settings.DATABASES = DATABASES

Command().execute(table_name_filter=lambda table_name: table_name in ('table_what_you_need_1', 'table_what_you_need_2', ), database='default')

https://github.com/django/django/blob/master/django/core/management/commands/inspectdb.py#L32

答案 2 :(得分:2)

您可以在Django 2.2或更高版本中通过以下命令进行操作

python manage.py inspectdb --database=[dbname] [table_name] > output.py

答案 3 :(得分:0)

您可以生成模型的python代码并以编程方式写入控制台。

from django.core.management.commands.inspectdb import Command

command = Command()
command.execute(
    database='default',
    force_color=True,
    no_color=False,
    include_partitions=True,
    include_views=True,
    table=[
        'auth_group',
        'django_session'
    ]
)

设置table=[]空列表以获取所有表

答案 4 :(得分:0)

您可以通过执行以下操作获得所需表的模型:

python manage.py inspectdb table1 table2 tableN > output.py

这样,您可以仅选择所需的表。