我正在为我的django项目使用多数据库系统。
但是当我尝试保存表单时,我收到此错误:save()得到了一个意外的关键字参数'使用'
这是我的简单代码:
我的观点:
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
提前感谢您的帮助。 :)
答案 0 :(得分:3)
using=
关键字参数位于模型save()
方法上,而不是ModelForm
保存方法。你应该这样做:
...
if request.method == 'POST':
formCompany2 = CompanyForm2(request.POST, instance=selectedObject)
selectedObject = formCompany2.save(commit=False)
selectedObject.save(using='dataset')
...
答案 1 :(得分:1)
文档没有说明表单的save方法的using
参数。但是,有一个模型保存。因此,您可以通过使用commit = False保存来获取模型对象,然后使用using
保存它:
selectedObject = formCompany2.save(commit=False)
selectedObject.save(using='dataset')
答案 2 :(得分: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'
感谢大家的帮助:)