0

我用的是django1.3,想把我的数据放到1000个数据库中,比如app_idmod_0~ap_idmod_999。现在我改变了我的设置。

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
        'NAME': 'myapp',                      # Or path to database file if using sqlite3.
        'USER': 'root',
        'PASSWORD': 'root',
        'HOST': '',                      # Set to empty string for localhost. Not used with sqlite3.
        'PORT': '3306',                      # Set to empty string for default. Not used with sqlite3.

    },    
}
myapp = DATABASES['default']
DB_MOD = 1000
for i in xrange(0, DB_MOD):
    myapp.__setitem__('NAME', 'myapp_idmod_' + str(i))
    DATABASES.__setitem__('myapp_idmod_' + str(i), myapp)

它不起作用。我的意思是,当我使用 时 manage.py syncdb --database=myapp_idmod_0,它不会生成表格。为什么?我怎样才能让它工作?

4

1 回答 1

0

首先,我无法想象1000 个数据库可能有什么用途。除非你是 Facebook,我对此表示怀疑。

其次,您将每个实例设置为同一个字典,因此当您在下一次迭代中更改名称时,之前的名称也会更改。您需要在更改字典之前复制字典。

最后,这一切到底是为了什么__setitem__?为什么不以正常方式设置字典值?

for i in xrange(DB_MOD):
    db_dict = myapp.copy()
    db_dict['NAME'] = 'myapp_idmod_' % i
    DATABASES['myapp_idmod_%s' % i] = db_dict
于 2011-08-04T06:45:09.433 回答