save() 得到一个意外的关键字参数 'using

3 投票
3 回答
4466 浏览
提问于 2025-04-17 23:33

我在我的Django项目中使用了一个多数据库系统。

但是当我尝试保存我的表单时,出现了这个错误:save() 收到了一个意外的关键字参数 'using'。

这是我的简单代码:

我的视图:

def addCompany2(request):
"""Add a company"""

    selectedObject = CompanyDataset()

if request.method == 'POST':
    formCompany2 = CompanyForm2(request.POST, instance=selectedObject)
    selectedObject = formCompany2.save(using='dataset')
else:
    formCompany2 = CompanyForm2(instance=selectedObject)

return render_to_response('company/addCompany2.html', {'referer': referer, 'formCompany2': formCompany2}, context_instance=RequestContext(request))

我的模型:

class CompanyDataset(models.Model):
    name = models.CharField(max_length=255, blank=True)
    ....
    ...
    ...

    def __unicode__(self):
        return self.name

    class Meta:
        db_table = 'company_dataset'
        managed = True

我的表单:

class CompanyForm2(ModelForm):

    class Meta:
        model = CompanyDataset
        #exclude = ('website')

    def __init__(self, *args, **kwargs):
        super(CompanyForm2, self).__init__(*args, **kwargs)

        self.fields.keyOrder = [
            'nom',
            'country'
            ]

settingsLocal:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'XXXXX',
        'USER': 'XXXXX',
        'PASSWORD': 'XXXXX',
        'HOST': '127.0.0.1',
        'PORT': '',
    },
    'dataset': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'XXXXX',
        'USER': 'XXXXX',
        'PASSWORD': 'XXXXX',
        'HOST': '127.0.0.1',
        'PORT': '5432',
    }
}

根据文档:https://docs.djangoproject.com/en/1.6/topics/db/multi-db/,我不明白为什么它不工作?我可能做错了什么,但我找不到问题出在哪里。

我的Django版本是:1.6.2

提前感谢你的帮助。:)

3 个回答

2

文档里没有提到表单保存方法的 using 参数。不过,模型的保存方法是有这个参数的。所以你可以先用 commit=False 保存模型对象,然后再用 using 来保存它:

selectedObject = formCompany2.save(commit=False)
selectedObject.save(using='dataset')
3

这里提到的 using= 这个参数是用在模型的 save() 方法上的,而不是在 ModelForm 的保存方法上。你应该这样做:

...

if request.method == 'POST':
    formCompany2 = CompanyForm2(request.POST, instance=selectedObject)
    selectedObject = formCompany2.save(commit=False)
    selectedObject.save(using='dataset')

...
1

解决办法是创建一个数据库用户:https://docs.djangoproject.com/en/dev/topics/db/multi-db/#database-routers

这里有一个和我最开始问题相关的工作示例:

dbRouter.py

import django
from company.models import CompanyDataset


class CompanyDatasetRouter(object):

    def db_for_read(self, model, **hints):
        #if isinstance(model, CompanyDataset):
        if model == CompanyDataset:
            return 'dataset'
        else:
            return 'default'

    def db_for_write(self, model, **hints):
        if model == CompanyDataset:
            return 'dataset'
        else:
            return 'default'

感谢大家的帮助 :)

撰写回答