我想使用外部脚本预填充我的数据库。脚本如下从外部脚本访问django sqlite数据库
# -*- coding:utf-8-*-
import os, sys
from random import choice
PROJECT_DIR = os.path.abspath(os.path.join(os.path.abspath(__file__),'..','..'))
sys.path.append(PROJECT_DIR)
os.environ['DJANGO_SETTINGS_MODULE']='geoedu.settings'
from school.models import School
from student.models import Student
if __name__=='__main__':
student = Student(first_name=choice(first_names_males), last_name=choice(last_names_males),
father_name=choice(first_names_males), mother_name=choice(first_names_females),
mobile=choice(mobiles), telephone=choice(telephones))
student.save()
其中在选择的参数是名单和电话列表。当我运行它,虽然我得到以下错误
django.db.utils.DatabaseError: no such table: student_student
目录树
geoedu
├── geoedu
│ ├── __init__.py
│ ├── __init__.pyc
│ ├── settings.py
│ ├── settings.pyc
│ ├── urls.py
│ ├── urls.pyc
│ ├── wsgi.py
│ └── wsgi.pyc
├── geoedu.db
├── geoedu.sublime-project
├── geoedu.sublime-workspace
├── manage.py
├── school
│ ├── admin.py
│ ├── admin.pyc
│ ├── __init__.py
│ ├── __init__.pyc
│ ├── models.py
│ ├── models.pyc
│ ├── tests.py
│ └── views.py
├── scripts
│ └── populate.py
└── student
├── admin.py
├── admin.pyc
├── __init__.py
├── __init__.pyc
├── models.py
├── models.pyc
├── tests.py
└── views.py
它所做的是它创建的脚本文件夹中的一个新的geoedu.db并使用(这是空的,没有student_student的课程表)
为什么会发生这种情况?PROJECT_DIR是正确的(打印出来),它是所有顶层geodedu树的根。
编辑:新建geoedu.db时创建新学生。如果我注释掉这些行geoedu.db没有创建。
,但在设置你怎么有定义的数据库结构文件? – Juliusz
你的意思是怎样的? ENGINE':'django.db.backends.sqlite3',。 'NAME':'geoedu.db',... etc 它与project_dir在相同的目录中创建,您可以从树命令中看到。 – Apostolos
工作......猜测使用sqlite3时,数据库的名称必须始终是路径而不只是名称。感谢@Juliusz为我指出了正确的方向 – Apostolos