Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/21.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 定义多个数据库时,Django Syncdb的默认行为是什么?_Python_Django - Fatal编程技术网

Python 定义多个数据库时,Django Syncdb的默认行为是什么?

Python 定义多个数据库时,Django Syncdb的默认行为是什么?,python,django,Python,Django,在我的设置中定义了两个数据库,一个是postgresql的默认数据库,另一个是外部系统上仅用于只读访问的mysql数据库 我为mysql数据库上未在已安装的应用程序中注册的模型分离了文件,当我想访问该数据库时,我使用对象。使用(“otherdb”)获取数据 问题是最近注意到了奇怪的行为:mysql服务器现在无法访问,它崩溃了syncdb 不管怎样,现在我在本地设置中有以下内容: class DumbRouter(object): def db_for_read(self, model,

在我的设置中定义了两个数据库,一个是postgresql的默认数据库,另一个是外部系统上仅用于只读访问的mysql数据库

我为mysql数据库上未在已安装的应用程序中注册的模型分离了文件,当我想访问该数据库时,我使用对象。使用(“otherdb”)获取数据

问题是最近注意到了奇怪的行为:mysql服务器现在无法访问,它崩溃了syncdb

不管怎样,现在我在本地设置中有以下内容:

class DumbRouter(object):
    def db_for_read(self, model, **hints):
        return 'default'

    def db_for_write(self, model, **hints):
        return 'default'

    def allow_relation(self, db1, db2, **hints):
        return False

    def allow_syncdb(self, db, model):
        return db in ('default',)


DATABASE_ROUTERS = ['pathtomyawesomeprojectanditssettings.DumbRouter']


DATABASES = {
    "default" : {
        'ENGINE': 'django.db.backends.sqlite3', 
        'NAME': location + 'sqlite3.db',                      
        'USER': 'django',                      
        'PASSWORD': '',                  
        'HOST': '',                      
        'PORT': '',                     
    },

    "otherserver": {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'anotherserver',  
        'USER': 'someuser',  
        'PASSWORD': 'asxasxasxasx', 
        'HOST': 'someipthatisnotup', 
        'PORT': '13306', 
    }

}
问题是,当我运行syncdb时,我无法连接到…MySQL服务器 所以我的问题是:为什么django试图访问那个服务器,而我的路由器明确地说它应该只使用默认值


更重要的是,我如何防止这种行为,并仅为objects.using定义DB

它将使用默认数据库。在您的示例中,将使用您要连接的sqlite3数据库。保留默认值。 此链接可能会有所帮助


如果它使用我的默认数据库,为什么在尝试连接到db时会出现MySQL错误?它甚至不应该尝试连接到那里…我不知道你为什么使用数据库路由器,我不知道数据库路由器。我正在使用django和sqlite3作为默认数据库。它工作正常。