簡體   English   中英

如何將視圖中的變量值存儲到 Django 模型?

[英]How can I store the variables values from views to the Django models?

在我的終端中,名稱和分數的值正在顯示,但如何將這兩個變量值存儲到特定模型(結果)中。

模型.py:

class Results(models.Model):
    username = models.CharField(max_length=50,default='')
    score = models.IntegerField(null=True,blank=True)

意見.py:

@login_required
def html2(request):
    name = request.GET.get('name')
    scores = request.GET.get('scores')
    print(name, scores)
    save_data = Results.objects.create(username=name, score=scores)
    context = {
        'data': save_data
    }

    return render(request,'quiz/html/html2.html',context)

終端:

[29/May/2020 13:15:22] "GET /api2/?format=json HTTP/1.1" 200 1467
Pavana 40

我試過這個語句,但它顯示了not null 約束錯誤,所以我刪除了那個語句錯誤:

    Traceback:

File "C:\Python38-32\lib\site-packages\django\db\backends\utils.py" in _execute
  85.                 return self.cursor.execute(sql, params)

File "C:\Python38-32\lib\site-packages\django\db\backends\sqlite3\base.py" in execute
  296.         return Database.Cursor.execute(self, query, params)

The above exception (NOT NULL constraint failed: quiz_results.username) was the direct cause of the following exception:

File "C:\Python38-32\lib\site-packages\django\core\handlers\exception.py" in inner
  34.             response = get_response(request)

File "C:\Python38-32\lib\site-packages\django\core\handlers\base.py" in _get_response
  126.                 response = self.process_exception_by_middleware(e, request)

File "C:\Python38-32\lib\site-packages\django\core\handlers\base.py" in _get_response
  124.                 response = wrapped_callback(request, *callback_args, **callback_kwargs)

File "C:\Python38-32\lib\site-packages\django\contrib\auth\decorators.py" in _wrapped_view
  21.                 return view_func(request, *args, **kwargs)

File "C:\Users\user\dev\samplequiz\quiz\views.py" in html2
  58.     save_data = Results.objects.create(username=name, score=scores)

File "C:\Python38-32\lib\site-packages\django\db\models\manager.py" in manager_method
  82.                 return getattr(self.get_queryset(), name)(*args, **kwargs)

File "C:\Python38-32\lib\site-packages\django\db\models\query.py" in create
  413.         obj.save(force_insert=True, using=self.db)

File "C:\Python38-32\lib\site-packages\django\db\models\base.py" in save
  717.         self.save_base(using=using, force_insert=force_insert,

File "C:\Python38-32\lib\site-packages\django\db\models\base.py" in save_base
  748.             updated = self._save_table(raw, cls, force_insert, force_update, using, update_fields)

File "C:\Python38-32\lib\site-packages\django\db\models\base.py" in _save_table
  831.             result = self._do_insert(cls._base_manager, using, fields, update_pk, raw)

File "C:\Python38-32\lib\site-packages\django\db\models\base.py" in _do_insert
  868.         return manager._insert([self], fields=fields, return_id=update_pk,

File "C:\Python38-32\lib\site-packages\django\db\models\manager.py" in manager_method
  82.                 return getattr(self.get_queryset(), name)(*args, **kwargs)

File "C:\Python38-32\lib\site-packages\django\db\models\query.py" in _insert
  1136.         return query.get_compiler(using=using).execute_sql(return_id)

File "C:\Python38-32\lib\site-packages\django\db\models\sql\compiler.py" in execute_sql
  1289.                 cursor.execute(sql, params)

File "C:\Python38-32\lib\site-packages\django\db\backends\utils.py" in execute
  100.             return super().execute(sql, params)

File "C:\Python38-32\lib\site-packages\django\db\backends\utils.py" in execute
  68.         return self._execute_with_wrappers(sql, params, many=False, executor=self._execute)

File "C:\Python38-32\lib\site-packages\django\db\backends\utils.py" in _execute_with_wrappers
  77.         return executor(sql, params, many, context)

File "C:\Python38-32\lib\site-packages\django\db\backends\utils.py" in _execute
  85.                 return self.cursor.execute(sql, params)

File "C:\Python38-32\lib\site-packages\django\db\utils.py" in __exit__
  89.                 raise dj_exc_value.with_traceback(traceback) from exc_value

File "C:\Python38-32\lib\site-packages\django\db\backends\utils.py" in _execute
  85.                 return self.cursor.execute(sql, params)

File "C:\Python38-32\lib\site-packages\django\db\backends\sqlite3\base.py" in execute
  296.         return Database.Cursor.execute(self, query, params)

Exception Type: IntegrityError at /
Exception Value: NOT NULL constraint failed: quiz_results.username

save_data = Results.objects.create(username=name, score=scores)

如何將姓名和分數存儲到結果 model 中。

這是因為數據庫表中列的所有字段都是null,這樣不好。 您必須至少有一個字段是非空的,因此請刪除用戶名中的 default=''。 即它應該看起來像這樣username = models.CharField(max_length=50 )之后運行 makemigrations 和 migrate 命令以與數據庫同步。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM