【发布时间】:2012-05-25 16:10:46
【问题描述】:
在此处提出的类似查询:Getting db_type() error while using django-facebook connect for DjangoApp
我正在尝试在 CentOS 机器上安装 Pootle,并提供以下详细信息:
[root@localhost pootle]# cat /etc/redhat-release<br>
CentOS release 6.2 (Final)
<br>
[root@localhost pootle]# PootleServer --version<br>
Pootle 2.1.6<br>
Translate Toolkit 1.9.0<br>
Django 1.4<br>
[root@localhost pootle]# python -V<br>
Python 2.6.6
我收到以下错误:
Creating tables ...
Traceback (most recent call last):
File "/usr/lib64/python2.6/wsgiref/handlers.py", line 94, in run
self.finish_response()
File "/usr/lib64/python2.6/wsgiref/handlers.py", line 134, in finish_response
for data in self.result:
File "/usr/lib/python2.6/site-packages/django/http/__init__.py", line 710, in next
chunk = self._iterator.next()
File "/usr/lib/python2.6/site-packages/pootle_misc/dbinit.py", line 134, in staggered_install
yield syncdb()
File "/usr/lib/python2.6/site-packages/pootle_misc/dbinit.py", line 76, in syncdb
call_command('syncdb', interactive=False)
File "/usr/lib/python2.6/site-packages/django/core/management/__init__.py", line 150, in call_command
return klass.execute(*args, **defaults)
File "/usr/lib/python2.6/site-packages/django/core/management/base.py", line 232, in execute
output = self.handle(*args, **options)
File "/usr/lib/python2.6/site-packages/django/core/management/base.py", line 371, in handle
return self.handle_noargs(**options)
File "/usr/lib/python2.6/site-packages/django/core/management/commands/syncdb.py", line 91, in handle_noargs
sql, references = connection.creation.sql_create_model(model, self.style, seen_models)
File "/usr/lib/python2.6/site-packages/django/db/backends/creation.py", line 44, in sql_create_model
col_type = f.db_type(connection=self.connection)
TypeError: db_type() got an unexpected keyword argument 'connection'
在我将 /usr/lib/python2.6/site-packages/django/db/backends/creation.py 编辑为我认为可以纠正问题的方式后,我仍然得到当我尝试加载网页时,来自我的 PootleServer 屏幕的以下输出:
Creating tables ...
Traceback (most recent call last):
File "/usr/lib64/python2.6/wsgiref/handlers.py", line 94, in run
self.finish_response()
File "/usr/lib64/python2.6/wsgiref/handlers.py", line 134, in finish_response
for data in self.result:
File "/usr/lib/python2.6/site-packages/django/http/__init__.py", line 710, in next
chunk = self._iterator.next()
File "/usr/lib/python2.6/site-packages/pootle_misc/dbinit.py", line 134, in staggered_install
yield syncdb()
File "/usr/lib/python2.6/site-packages/pootle_misc/dbinit.py", line 76, in syncdb
call_command('syncdb', interactive=False)
File "/usr/lib/python2.6/site-packages/django/core/management/__init__.py", line 150, in call_command
return klass.execute(*args, **defaults)
File "/usr/lib/python2.6/site-packages/django/core/management/base.py", line 232, in execute
output = self.handle(*args, **options)
File "/usr/lib/python2.6/site-packages/django/core/management/base.py", line 371, in handle
return self.handle_noargs(**options)
File "/usr/lib/python2.6/site-packages/django/core/management/commands/syncdb.py", line 91, in handle_noargs
sql, references = connection.creation.sql_create_model(model, self.style, seen_models)
File "/usr/lib/python2.6/site-packages/django/db/backends/creation.py", line 45, in sql_create_model
col_type = f.db_type(self.connection)
TypeError: db_type() takes exactly 1 argument (2 given)
网页显示:
Error: "(1146, "Table 'p2.siteconfig_siteconfiguration' doesn't exist")" while attempting to access the Pootle database, will try to initialize database.
有问题的行是第 44 行,如下所示:
col_type = f.db_type(connection=self.connection)
我已将其注释掉,并在其下方添加了一行,如下所示:
#col_type = f.db_type(connection=self.connection)
col_type = f.db_type(self.connection)
之前运行服务器呈现了这个错误,但是它之前有一些成功的创建通知,我们可以在这里看到:
mysql> show tables;
+-----------------------------------------------+
| Tables_in_p2 |
+-----------------------------------------------+
| auth_group |
| auth_group_permissions |
| auth_permission |
| auth_user |
| auth_user_groups |
| auth_user_user_permissions |
| django_admin_log |
| django_content_type |
| django_session |
| django_site |
| pootle_app_directory |
| pootle_app_language |
| pootle_app_permissionset |
| pootle_app_permissionset_negative_permissions |
| pootle_app_permissionset_positive_permissions |
| pootle_app_pootleprofile |
| pootle_app_pootleprofile_alt_src_langs |
| pootle_app_pootleprofile_languages |
| pootle_app_pootleprofile_projects |
| pootle_app_project |
| pootle_app_submission |
| pootle_app_suggestion |
| pootle_app_translationproject |
| pootle_notifications_notice |
| pootle_store_qualitycheck |
| pootle_store_store |
| pootle_store_suggestion |
| pootle_store_unit |
| registration_registrationprofile |
+-----------------------------------------------+
29 rows in set (0.00 sec)
很抱歉,如果这是一个冗长的问题,但我正在尝试提供尽可能多的相关信息,以便让您对正在发生的事情有一个很好的了解。
如果您知道解决此问题的方法,请告诉我,因为互联网似乎相当缺乏与 Pootle 相关的修复。
编辑: 看到了这个:How to fix django's db_type deprecation warning?
将 settings.py 文件更改为包含以下内容:
col_type = f.db_type(connection=connection)
#col_type = f.db_type(connection=self.connection)
#col_type = f.db_type(self.connection)
收到此错误:
NameError: global name 'connection' is not defined
【问题讨论】:
-
刚刚使用空白数据库尝试了不同的方法来尝试编写 db_type 函数,并且软件附带的那个看起来绝对正确....但它仍然无法正常工作:\
-
我很想知道如果数据库已经存在,它是否会跳过这个......可能不会,我找不到它的结构......
-
我不确定 Pootle 是否与 Django 1.4 兼容,过去通常需要一段时间才能发布与最新 Django 兼容的版本。
-
两年后,再补充一点,我不知道我当时在做什么。我希望我可以为我正在做的事情提供一个解决方案,所以我对访问此页面的 Google 员工深表歉意!