1

我想使用外部脚本预填充我的数据库。脚本如下

# -*- 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 不会被创建。

4

2 回答 2

0

在 Django 中定义模型可以帮助您操作实例。

但是,在此之前,您必须在您的 sqlite 数据库中创建表“骨架”

为此,您只需要通过执行以下操作将数据库与 Django 同步:

python manage.py syncdb

此操作只需执行一次。

将来,您可能需要使您的模型演变(因此需要类似的数据库演变),此时 South - 或临时模式演变查询 - 将很有用(http://south.aeracode.org/)但到目前为止在进行原型设计时,您可以删除 db 并通过执行 syncdb 用好的表重新创建它

于 2014-01-07T16:44:27.480 回答
0

问题是我没有在 settings.py 文件中使用数据库名称的绝对路径。我在数据库引擎的名称中添加了这个

'NAME':os.path.join(SETTINGS_DIR,'geoedu.db')

一切正常。PROJECT_DIR 是

SETTINGS_DIR = os.path.dirname(__file__)

所以数据库是在设置文件夹中创建的。如果你想在项目文件夹中,你应该这样做

'NAME':os.path.abspath(os.path.join(SETTINGS_DIR,'..','geoedu.db'))
于 2014-01-07T20:36:19.480 回答