在一个芹菜任务中,我需要在数据库中创建临时表。 Daniel Roseman在this article中解释了如何创建一个。但是这个解决方案在Django 1.9中不起作用。我试图研究Django文档和Google,但是我找不到任何有用的东西。从提到的文章django中的临时模型1.9
守则,在Django 1.8工作:
from django.db import models, cursor
from django.contrib.contenttypes.management import update_contenttypes
from django.core.management import call_command
class TempCustomerAddress(models.Model):
address = models.ForeignKey('accounts.Address')
legacy_id = models.CharField(max_length=12, unique=True)
class Meta:
app_label = 'utils'
class Command(NoArgsCommand):
def handle_noargs(self, **options):
models.register_models('utils', TempCustomerAddress)
models.signals.post_syncdb.disconnect(update_contenttypes)
call_command('syncdb')
# ... do importing and stuff referring to TempCustomerAddress ...
cursor = connection.cursor()
cursor.execute('DROP TABLE `utils_tempcustomeraddress`')
我应该说,利用克隆一个deepcopy的字段()不是一个完整的解决方案...这只是一个例子。 deepcopy()保留将复制的字段绑定回原始模型的各种数据。 –
FWIW,事实证明Field.clone()知道如何复制一个字段。答案更新,以反映这一点。 –