gpt4 book ai didi

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

转载 作者:太空狗 更新时间:2023-10-29 21:34:43 25 4
gpt4 key购买 nike

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

这是我的类(class)的代码(在我的应用程序的 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) 为什么我会看到“<绑定(bind)方法 Question.save of >”?

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

谢谢。

最佳答案

Model.save 是一个方法

你应该运行:

q.save()

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

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

关于python - 为什么我的数据库不能在此 Python/Django 应用程序中运行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19555796/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com