【发布时间】:2018-03-01 03:13:31
【问题描述】:
我的目的是动态生成 Django 模型。
我使用以下代码创建模型。
def create_model(name, fields=None, app_label='', module='', options=None, admin_opts=None):
class Meta:
# Using type('Meta', ...) gives a dictproxy error during model creation
pass
if app_label:
# app_label must be set using the Meta inner class
setattr(Meta, 'app_label', app_label)
# Update Meta with any options that were provided
if options is not None:
for key, value in options.iteritems():
setattr(Meta, key, value)
# Set up a dictionary to simulate declarations within a class
attrs = {'__module__': module, 'Meta': Meta}
# Add in any fields that were provided
if fields:
attrs.update(fields)
# Create the class, which automatically triggers ModelBase processing
model = type(name, (models.Model,), attrs)
# Create an Admin class if admin options were provided
if admin_opts is not None:
class Admin(admin.ModelAdmin):
pass
for key, value in admin_opts:
setattr(Admin, key, value)
admin.site.register(model, Admin)
return model
然后我知道我需要从模型生成 sql 并同步到数据库中。
我使用以下代码:
def install(custom_model):
from django.core.management import color
from django.db import connection
from django.db.backends.base import schema
style = color.no_style()
cursor = connection.cursor()
statements, pending = connection.creation.sql_create_model(custom_model, style)
for sql in statements:
cursor.execute(sql)
但是,它告诉我
AttributeError: 'DatabaseCreation' object has no attribute 'sql_create_model'
我的 Django 版本是 2.0,是的,它没有 sql_create_model。
我的问题是如何使用 Django 2.0 从模型生成 sql?
非常感谢。
【问题讨论】:
标签: django-models