django admin指定数据库(不是默认值)

时间:2014-01-09 14:00:37

标签: django django-models

我正在使用django admin来帮助编辑数据库。最近,我们添加了另一个数据库,因此在设置文件中使用DATABASES中的默认值将不再有意义。

我现在在settings.py文件中有这个:

DATABASES = {
    'default': {},
    'animal_tracking': {
        'ENGINE':'django.db.backends.mysql',
        'NAME': 'AnimalTracking',
        'USER': 'foo',
        'PASSWORD': 'bar',
        'HOST': '127.0.0.1',
        'PORT': '3306',
    },
    'animal_information': {
        'ENGINE':'django.db.backends.mysql',
        'NAME': 'AnimalInformation',
        'USER': 'foo',
        'PASSWORD': 'bar',
        'HOST': '127.0.0.1',
        'PORT': '3306',
    },
}

我的admin.py文件包含:

from django.contrib import admin
from animal_tracking.models import at_animal_types, at_animals
# Register your models here.

class AnimalTypesAdmin(admin.ModelAdmin):
    # Sets how the fields are displayed in the add / change section.
    fieldsets = [
        (None,               {'fields': ['type', ]}),
    ]
    # Sets what fields to be displayed in the change (view) section.
    list_display = ('type', )
# Registers the current model administration to the admin page.
admin.site.register(at_animal_types, AnimalTypesAdmin)

class AnimalsAdmin(admin.ModelAdmin):
    # Sets how the fields are displayed in the add / change section.
    fieldsets = [
        (None,               {'fields': ['tracker_id', 'type', ]}),
        ('Log information (should not change)', {'fields': ['last_log', 'last_bat', 'last_lat', 'last_lon', ], 'classes': ['collapse']}),
    ]
    # Sets what fields to be displayed in the change (view) section.
    list_display = ('tracker_id', 'type', 'last_log', 'last_bat', 'last_lat', 'last_lon', )
    # Sets what fields to allow filtering by.
    list_filter = ['type', ]
    # Sets what fields to allow searching by. Use table__field if foreign key.
    search_fields = ['tracker_id', 'type__type', ]
# Registers the current model administration to the admin page.
admin.site.register(at_animals, AnimalsAdmin)

最初,admin部分将与默认数据库连接。但是现在我删除了默认值并添加了其他2个数据库,我收到以下错误:

Django error.

如果我将animal_tracking的设置复制到默认值,则可以正常工作。因此,我的问题是:

如何指定django admin应使用哪个数据库?

谢谢!

1 个答案:

答案 0 :(得分:1)

更好地指定默认数据库,如果您将默认值设为空,则应编写db routers

在您的管理员中,您可以使用您喜欢的任何数据库:

class AnimalTypesAdmin(admin.ModelAdmin):
    using = 'animal_tracking'
    def get_queryset(self, request):
        # Tell Django to look for objects on the 'other' database.
        return super(MultiDBModelAdmin, self).get_queryset(request).using(self.using)

save_modeldelete_modelformfield_for_foreignkeyformfield_for_manytomany也应该像示例中的this一样被覆盖。

相关问题