0

在我的网站中,每个用户都有自己的登录 ID 和密码,所以如果用户登录,他只能添加、编辑和更新他的记录。

模型.py 是

class Report(models.Model):
    user = models.ForeignKey(User, null=False)
    name = models.CharField(max_length=20, null=True, blank=True)

视图.py

def profile(request):      
    if request.method == 'POST':    
        reportform = ReportForm(request.POST)

        if reportform.is_valid():
            report = reportform.save(commit=False)
            report.user = request.user
            report.save()
            return redirect('/index/')

    else:
        report = Report.objects.get()
        reportform = ReportForm(instance=report)

    return render_to_response('report/index.html',
                   { 'form': reportform, },
                   context_instance=RequestContext(request))

用户应该有一个年龄,并且应该在数据库中的一行数据中。

  1. 如果数据库中没有数据,即用户是第一次,则允许用户向数据库中插入数据。
  2. 如果用户重新打开页面,插入的数据应该以可编辑模式显示。

这就像“如果一个新用户创建一个 gmail 帐户,他可以在第一次创建帐户,他只能编辑和更新他们的详细信息”的场景。我想在我的网站中实施相同的程序。

我用上面的代码试过了,我无法在数据库中插入数据。我尝试在 mysql db 中直接插入并检查,所以我可以在可编辑模式下看到插入的数据,但如果我更改并保存,它会在 db 中创建另一行数据。

然后,如果我要第一次插入它,我会得到以下跟踪。

Environment:    

Request Method: GET
Request URL: http://192.168.100.10/report/index/

Django Version: 1.3.7
Python Version: 2.7.0
Installed Applications:
['django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.sites',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'django.contrib.admin',
 'django.contrib.admindocs',
 'django.contrib.humanize',
 'django.contrib.staticfiles',
 'south',
 'collect',
 'incident',
 'report_settings']
Installed Middleware:
('django.middleware.common.CommonMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.transaction.TransactionMiddleware',
 'django.middleware.cache.FetchFromCacheMiddleware')


Traceback:
File "/usr/lib/python2.7/site-packages/django/core/handlers/base.py" in get_response
  111.                         response = callback(request, *callback_args, **callback_kwargs)
File "/root/Projects/ir/incident/views.py" in when
  559.         report = Report.objects.get()
File "/usr/lib/python2.7/site-packages/django/db/models/manager.py" in get
  132.         return self.get_query_set().get(*args, **kwargs)
File "/usr/lib/python2.7/site-packages/django/db/models/query.py" in get
  349.                     % self.model._meta.object_name)

Exception Type: DoesNotExist at report/index/
Exception Value: Report matching query does not exist.
4

2 回答 2

0

根据您显示的代码,您最可能的问题是Report没有保存到数据库中。您没有说任何关于ReportForm您正在使用的内容或与之一起使用的数据,但很可能以下部分永远不会执行:

if reportform.is_valid():
    report = reportform.save(commit=False)
    (...)

因此,不会保存任何报告。因此,当您到达此行时:

report = Report.objects.get()

...你会得到你提到的回溯。我建议用 or 替换.get().all()因为.filter()当没有匹配的结果时它们不会抛出异常。

要更新数据,您应该首先从数据库中获取报表实例,并将其传递给表单的save函数:

report = Report.objects.filter(name=some_value)
report.user = request.user
reportform.save(instance=report)
于 2013-05-04T11:14:56.797 回答
0
report = Report.objects.get()
reportform = ReportForm(instance=report)

我试图在我的一个示例中运行一个空的 .get() ,它给了我类似的错误。如果您要获取所有实体,请尝试所有实体,因为 get only 会让您返回一个独特的项目:

report = Report.ojbects.all()
于 2017-07-02T22:22:25.337 回答