save() 得到一个意外的关键字参数 'using
我在我的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'
感谢大家的帮助 :)