为什么我的数据库不能在这个Python / Django应用程序中运行?

时间:2013-10-24 02:24:04

标签: python mysql django shell

我正在尝试完成Django教程,我的代码中的所有内容都在工作,直到我尝试保存并打印对象的实例变量。

这是我的类的代码(这是我的应用程序的models.py文件中):

from django.db import models

class Question(models.Model):
    question_text = models.CharField(max_length=200)
    pub_date = models.DateTimeField('date published')

然后我把它输入终端:

$ python manage.py sql polls

返回此输出:

BEGIN;

CREATE TABLE `polls_question` (

`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,
`question_text` varchar(200) NOT NULL,
`pub_date` datetime NOT NULL

)
;
CREATE TABLE `polls_choice` (
`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,
`question_id` integer NOT NULL,
`choice_text` varchar(200) NOT NULL,
`votes` integer NOT NULL
)
;

ALTER TABLE `polls_choice` ADD CONSTRAINT `question_id_refs_id_f3f98eca` FOREIGN KEY (`question_id`) REFERENCES `polls_question` (`id`);

COMMIT;

然后我把它输入我的终端:

$ python manage.py syncdb

返回此内容:

Creating tables ...
Installing custom SQL ...
Installing indexes ...
Installed 0 object(s) from 0 fixture(s)

然后我输入这个终端来启动python shell:

$ python manage.py shell

这是终端内的输入/输出:

In [1]: from polls.models import Question, Choice

In [2]: Question.objects.all()
Out[2]: []

In [3]: from django.utils import timezone

In [4]: q = Question(question_text="What's new?", pub_date=timezone.now())

In [5]: q.save
Out[5]: <bound method Question.save of <Question: Question object>>
#tutorial does not show this above line appearing

In [6]: q.id
#tutorial says I should get an output from this

我的问题:

1)为什么我看到“&lt;绑定方法Question.save of&gt;”?

2)当我调用对象的id时,为什么我没有得到任何输出?

感谢。

1 个答案:

答案 0 :(得分:9)

Model.save是一种方法

你应该跑:

q.save()

在控制台中键入q.save只会打印方法的字符串表示形式。

因为您从未将模型对象保存到数据库,所以模型对象没有id。