gpt4 book ai didi

Django 对我的 DATABASES 设置做了一些奇怪的事情

转载 作者:行者123 更新时间:2023-12-03 07:26:34 25 4
gpt4 key购买 nike

我想将数据库后端从 django_pyodbc 切换到 sqlite,以确保我的自定义用户模型在我开始弄乱我的数据库之前工作。所以我注释掉了 DATABASES 设置并添加了一个使用 sqlite 的新设置。我以前做过这个(在这个项目上也是)没有问题,但现在我不知道发生了什么。
syncdb响应好像它正在查看一个已经同步的数据库,即它什么也不做。

shell , settings.DATABASES 返回我原始数据库的设置(令人震惊的是,它仍然认为我正在使用几周前我为 django_pyodbc 切换的 sqlserver_ado 后端),并且我可以访问与我的用户模型,但那些确实返回错误的模型(因为我更改了一些用户字段名称)。在回溯中,我看到它仍在查看 MSSQL 数据库。
runserver有效,但是当我转到一个页面时,我得到一个 DatabaseError - 没有这样的表:django_session.异常位置在 ...\django\db\backends\sqlite3\...

这是完整的回溯:

Traceback:
File "C:\Python27\lib\site-packages\django\core\handlers\base.py" in get_response
187. response = middleware_method(request, response)
File "C:\Python27\lib\site-packages\django\contrib\sessions\middleware.py" in process_response
28. if request.session.get_expire_at_browser_close():
File "C:\Python27\lib\site-packages\django\contrib\sessions\backends\base.py" in get_expire_at_browser_close
253. if self.get('_session_expiry') is None:
File "C:\Python27\lib\site-packages\django\contrib\sessions\backends\base.py" in get
57. return self._session.get(key, default)
File "C:\Python27\lib\site-packages\django\contrib\sessions\backends\base.py" in _get_session
168. self._session_cache = self.load()
File "C:\Python27\lib\site-packages\django\contrib\sessions\backends\db.py" in load
18. expire_date__gt=timezone.now()
File "C:\Python27\lib\site-packages\django\db\models\manager.py" in get
143. return self.get_query_set().get(*args, **kwargs)
File "C:\Python27\lib\site-packages\django\db\models\query.py" in get
398. num = len(clone)
File "C:\Python27\lib\site-packages\django\db\models\query.py" in __len__
106. self._result_cache = list(self.iterator())
File "C:\Python27\lib\site-packages\django\db\models\query.py" in iterator
317. for row in compiler.results_iter():
File "C:\Python27\lib\site-packages\django\db\models\sql\compiler.py" in results_iter
775. for rows in self.execute_sql(MULTI):
File "C:\Python27\lib\site-packages\django\db\models\sql\compiler.py" in execute_sql
840. cursor.execute(sql, params)
File "C:\Python27\lib\site-packages\django\db\backends\util.py" in execute
41. return self.cursor.execute(sql, params)
File "C:\Python27\lib\site-packages\django\db\backends\sqlite3\base.py" in execute
366. six.reraise(utils.DatabaseError, utils.DatabaseError(*tuple(e.args)), sys.exc_info()[2])
File "C:\Python27\lib\site-packages\django\db\backends\sqlite3\base.py" in execute
362. return Database.Cursor.execute(self, query, params)

是的;我曾尝试再次打开和关闭计算机。有任何想法吗?谢谢你。

== 编辑 ==

这是我的数据库设置:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': PROJECT_ROOT.child('temp_db').child('sqlite.db'),
'USER': '',
'PASSWORD': '',
'HOST': '',
'PORT': '',
}
}

# DATABASES = {
# 'default': {
# 'ENGINE': 'django.db.backends.django_pyodbc',
# 'NAME': my_project,
# 'USER': '',
# 'PASSWORD': '',
# 'HOST': my_host,
# 'PORT': '',
# 'OPTIONS': {
# 'driver': 'SQL Server',
# 'MARS_Connection': True,
# }
# }
# }

== 编辑2 ==

我在设置文件夹中查找 __init__.py , base.py , dev.py及其关联的 .pyc 文件。另外还有一个 settings.pyc没有相应 .py 文件的文件(我假设这是在我将 settings.py 分割成单独的部分之前的残余。我尝试删除它并再次执行 syncdb 并得到了这个:
C:\...\my_project>manage.py syncdb --settings=my_project.settings.devettings=web_ems.
Traceback (most recent call last):
File "C:\...\my_project\manage.py", line 15, in <module>
if settings.DEBUG:
File "C:\Python27\lib\site-packages\django\conf\__init__.py", line 53, in __getattr__
self._setup(name)
File "C:\Python27\lib\site-packages\django\conf\__init__.py", line 48, in _setup
self._wrapped = Settings(settings_module)
File "C:\Python27\lib\site-packages\django\conf\__init__.py", line 134, in __init__
raise ImportError("Could not import settings '%s' (Is it on sys.path?): %s"% (self.SETTINGS_MODULE, e))

ImportError: Could not import settings 'my_project.settings.settings' (Is it on sys
.path?): No module named settings

最佳答案

您没有使用正确的设置模块,因此您所做的更改不会有任何效果。

可能的原因可能很多,但主要的可能性有两个:

  • 您正在使用来自错误位置的模块(即您的 PYTHONPATH 是错误的);
  • 您的 DJANGO_SETTINGS_MODULE是错的。

  • 额外提示:如果您想知道您正在使用什么设置模块,请打开 shell 并输入:
    >>> from django.conf import settings
    >>> settings.SETTINGS_MODULE
    'my_project.settings'

    那么,如果你想知道你是否在使用 my_project.settings从正确的路径,使用:
    >>> from my_project import settings
    >>> settings
    <module 'my_project.settings' from '...'>

    关于Django 对我的 DATABASES 设置做了一些奇怪的事情,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18617668/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com