我有一个包含1000个表格的模式,其中许多我不需要, 我怎样才能只检查我需要的那些表?
答案 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
这样,您可以仅选择所需的表。