Django 是“无法打开数据库文件";

Django is quot;unable to open database filequot;(Django 是“无法打开数据库文件;)
本文介绍了Django 是“无法打开数据库文件";的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

运行python manage.py syncdb"后,我收到一条错误消息无法打开数据库文件".

这是我的 settings.py 中的重要部分:

DATABASE_ENGINE = 'sqlite3' # 'postgresql_psycopg2'、'postgresql'、'mysql'、'sqlite3' 或 'oracle'.DATABASE_NAME = 'apps.db' # 如果使用 sqlite3,则为数据库文件的路径.DATABASE_USER = '' # 不与 sqlite3 一起使用.DATABASE_PASSWORD = '' # 不与 sqlite3 一起使用.DATABASE_HOST = '' # 设置为本地主机的空字符串.不与 sqlite3 一起使用.DATABASE_PORT = '' # 默认设置为空字符串.不与 sqlite3 一起使用.

这里是apps.db"的权限:

-rw-r--r-- 1 root root 33792 19. Jul 10:51 apps.db

我的 django 服务器是从 apache 调用的...我不知道它是否与权限有关,但是将 apps.db 的所有者更改为www-data"也不起作用

为了确保 www-data 可以访问所有这些,我做了以下操作:

做了以下事情:

chown -R www-data 应用程序rm 应用程序.dbsu www-数据python manage.py syncdb

但是还是不行:(

解决方案

我通过将 DATABASE_NAME 更改为绝对路径解决了错误:/var/www/apps/apps.db.p>

在 Windows 机器上,反斜杠应该转义为:C:\path\to\database\database_name.db.

after running "python manage.py syncdb" i gett an error saying "unable to open database file".

here is the important part from my settings.py:

DATABASE_ENGINE = 'sqlite3'    # 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
DATABASE_NAME = 'apps.db'      # Or path to database file if using sqlite3.
DATABASE_USER = ''             # Not used with sqlite3.
DATABASE_PASSWORD = ''         # Not used with sqlite3.
DATABASE_HOST = ''             # Set to empty string for localhost. Not used with sqlite3.
DATABASE_PORT = ''             # Set to empty string for default. Not used with sqlite3.

and here are the permissions for "apps.db":

-rw-r--r-- 1 root root 33792 19. Jul 10:51 apps.db

My django server is called from apache... i don't know if it has to do with the permissions but changing the owner of apps.db to "www-data" did not work either

[edit]

to ensure www-data can access all of this i did the following:

did the following:

chown -R www-data apps
rm apps.db
su www-data
python manage.py syncdb

but it still does not work :(

解决方案

I solved the error by changing the DATABASE_NAME to an absolute path: /var/www/apps/apps.db.

On a windows machine, backslash should be escaped like: C:\path\to\database\database_name.db.

这篇关于Django 是“无法打开数据库文件";的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

SQL/MySQL: split a quantity value into multiple rows by date(SQL/MySQL:按日期将数量值拆分为多行)
SQL Server Graph Database - shortest path using multiple edge types(SQL Server图形数据库-使用多种边类型的最短路径)
How should make faster SQL Server filtering procedure with many parameters(如何让多参数的SQL Server过滤程序更快)
FastAPI + Tortoise ORM + FastAPI Users (Python) - Relationship - Many To Many(FastAPI+Tortoise ORM+FastAPI用户(Python)-关系-多对多)
How can I generate an entity–relationship (ER) diagram of a database using Microsoft SQL Server Management Studio?(如何使用Microsoft SQL Server Management Studio生成数据库的实体关系(ER)图?)
Inserting NaN value into MySQL Database(将NaN值插入MySQL数据库)