Не в состоянии использовать набор запросов для нескольких баз данных в Django - PullRequest
1 голос
/ 18 января 2012

Я могу использовать набор запросов для базы данных по умолчанию.Но когда я использую набор запросов для другой базы данных, выдает исключение.

В моем приложении я использую две базы данных.sqlite и Mysql

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

, когда я использую набор запросов для первой базы данных, он не выдает никаких исключений.При использовании с использованием второй базы данных таблица метаний недоступна.

TemplateSyntaxError at /abc/xyz/

Caught DatabaseError while rendering: no such table: second.tablename

Request Method:     GET
Request URL:    http://127.0.0.1:8000/xxx/yyyy/?q=abcd
Django Version:     1.3.1
Exception Type:     TemplateSyntaxError
Exception Value:    

Caught DatabaseError while rendering: no such table: second.tablename

Ответы [ 2 ]

1 голос
/ 22 января 2012

Спасибо за ответ Том, я попробовал вторую базу данных вручную, и она сработала для меня.

   $model_seconddb.modelname.objects.using('seconddatabasename').filter(name='xxx')

Это можно использовать, когда все таблицы отсутствуют в обеих базах данных.1005 * Если вы хотите использовать базу данных по умолчанию, нет необходимости в использовании (использовании).Он будет напрямую запрашивать из базы данных по умолчанию.

0 голосов
/ 22 июня 2017

Лучший вариант использования нескольких баз данных в Django - это также использование маршрутизации для управления несколькими базами данных. Вот документация:

https://docs.djangoproject.com/en/1.11/topics/db/multi-db/#topics-db-multi-db-routing

Вот полный пример из документа:

class AuthRouter(object):
"""
A router to control all database operations on models in the
auth application.
"""
def db_for_read(self, model, **hints):
    """
    Attempts to read auth models go to auth_db.
    """
    if model._meta.app_label == 'auth':
        return 'auth_db'
    return None

def db_for_write(self, model, **hints):
    """
    Attempts to write auth models go to auth_db.
    """
    if model._meta.app_label == 'auth':
        return 'auth_db'
    return None

def allow_relation(self, obj1, obj2, **hints):
    """
    Allow relations if a model in the auth app is involved.
    """
    if obj1._meta.app_label == 'auth' or \
       obj2._meta.app_label == 'auth':
       return True
    return None

def allow_migrate(self, db, app_label, model_name=None, **hints):
    """
    Make sure the auth app only appears in the 'auth_db'
    database.
    """
    if app_label == 'auth':
        return db == 'auth_db'
    return None

Без указания базы данных в запросе, Django будет использовать правильную базу данных в базе имени таблицы.

Надеюсь, эта помощь:)

...