Django: dynamic database file

核能气质少年 提交于 2019-12-17 10:34:38

问题


In my Django project I have a dependency for a third party application that produces SQLite cache files in various directories with a known schema.

I'd like to use Django models to access those databases, but obviously I cannot use a static DATABASES setup.

How can I dynamically open a SQLite database on an arbitrary path?

EDIT

As Byron Ruth pointed out, the solution is to use the django.db.connections in conjunction with the using function in the QuerySet.


回答1:


The django.db.connections is a simple wrapper around DATABASES defined in your settings. The wrapper class is here: django.db.utils#L137-L227

from django.db import connections

# Add connection information dynamically..
connections.databases['new-alias'] = { ... }
# Ensure the remaining default connection information is defined.
# EDIT: this is actually performed for you in the wrapper class __getitem__
# method.. although it may be good to do it when being initially setup to
# prevent runtime errors later.
# connections.databases.ensure_defaults('new-alias')

# Use the new connection
conn = connections['new-alias']



回答2:


You can register database in DATABASES settings.

from your_project import settings
database_id = "unqique_name"
new_database = {}
new_database["id"] = database_id
new_database['ENGINE'] = 'django.db.backends.sqlite3'
new_database['NAME'] = '/project/data/db_%s.sql' % database_id
new_database['USER'] = ''
new_database['PASSWORD'] = ''
new_database['HOST'] = ''
new_database['PORT'] = ''
settings.DATABASES[database_id] = new_database

You can but you shouldn't.




回答3:


Assuming the only engine used is SQLite and the location of the (only) database file is what varies, provide a callable to the NAME:

def get_db_loc():
    # code to determine filesystem location of database
    return location

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': get_db_loc(),
        # More config goes here
    }
}


来源:https://stackoverflow.com/questions/14254315/django-dynamic-database-file

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!