добавить данные в M2M через модели - PullRequest
0 голосов
/ 17 июня 2019

Я пытаюсь сделать записи для своей базы данных веб-приложения для планирования курса в учреждении.Меня беспокоит то, что я не могу делать записи в промежуточной таблице, возникающей из отношения M2M в views.py, но он работает в оболочке в браузере. У меня ValueError: значение QuerySet для точного поиска должно быть ограниченоодин результат с использованием нарезки.

Traceback Переключиться в режим копирования и вставки

C:\Program Files\Python37\lib\site-packages\django\core\handlers\exception.py in inner

                response = get_response(request)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\core\handlers\base.py in _get_response

                    response = self.process_exception_by_middleware(e, request)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\core\handlers\base.py in _get_response

                    response = wrapped_callback(request, *callback_args, **callback_kwargs)

     ...
▶ Local vars
E:\PLACORESA\configuration\views.py in departemnent

                cursus = get_object_or_404(Cursus, libelle_cursus=cursus )

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\shortcuts.py in get_object_or_404

            return queryset.get(*args, **kwargs)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\query.py in get

            num = len(clone)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\query.py in __len__

            self._fetch_all()

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\query.py in _fetch_all

                self._result_cache = list(self._iterable_class(self))

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\query.py in __iter__

            results = compiler.execute_sql(chunked_fetch=self.chunked_fetch, chunk_size=self.chunk_size)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\sql\compiler.py in execute_sql

                sql, params = self.as_sql()

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\sql\compiler.py in as_sql

                    where, w_params = self.compile(self.where) if self.where is not None else ("", [])

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\sql\compiler.py in compile

                sql, params = node.as_sql(self, self.connection)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\sql\where.py in as_sql

                    sql, params = compiler.compile(child)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\sql\compiler.py in compile

                sql, params = node.as_sql(self, self.connection)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\lookups.py in as_sql

            rhs_sql, rhs_params = self.process_rhs(compiler, connection)

     ...
▶ Local vars
C:\Program Files\Python37\lib\site-packages\django\db\models\lookups.py in process_rhs

                        'The QuerySet value for an exact lookup must be limited to '

     ...
▶ Local vars 

models.py

class Departement(models.Model):
    code_departement=models.CharField("code du département", max_length=100, unique=True)
    libelle_departement=models.CharField("Libellé du département", max_length=100)
    faculte=models.ForeignKey("Faculte", on_delete=models.CASCADE)
    cursus=models.ManyToManyField("Cursus", through="AvoirCursus")   

class Cursus(models.Model):
    code_cursus=models.CharField("Code du cursus", max_length=10, unique=True)
    libelle_cursus=models.CharField("Libellé du cursus", max_length=100) 

class AvoirCursus(models.Model):
    cursus=models.ForeignKey("Cursus", on_delete=models.CASCADE)
    departement=models.ForeignKey("Departement", on_delete=models.CASCADE)

views.py

if request.method == 'POST':
        f = forms.Departement_Form(request.POST)
        if f.is_valid():
            dept = f.save(commit=False)
            code_departement = f.cleaned_data['code_departement'].upper()
            dept.code_departement = code_departement
            cursus = f.cleaned_data['cursus']
            dept.save()
            cursus = get_object_or_404(Cursus, libelle_cursus=cursus )

            AvoirCursus(departement=dept, cursus=cursus)

            return redirect('configuration:lister_departement')

Ответы [ 2 ]

0 голосов
/ 20 июня 2019

Мне удалось решить мою проблему.Формы, используемые в представлениях, являются общей формой из models.py.когда я печатал (cursus), результатом был набор запросов, содержащий выбранные элементы. Для записи в промежуточную базу данных я сделал курс "cursus", чтобы иметь разные объекты.

**the views.py is:**
if f.is_valid():
            dept = f.save(commit=False)
            code_departement = f.cleaned_data['code_departement']
            dept.code_departement = code_departement
            print(code_departement)
            cursus = f.cleaned_data['cursus']
            dept.save()
            for i in cursus:
                AvoirCursus.objects.create(departement=dept, cursus=i)
0 голосов
/ 17 июня 2019

Вы уверены, что объект cursus работает правильно?Может быть, cursus from form возвращает более одного значения или строки?

Кроме того, попробуйте добавить print (cursus) после get_or_404 и посмотрите, что внутри.

А что именно вы пытаетесь сделать здесь?

AvoirCursus (департамент = департамент, курс = курс)

Вы уверены, что это не должно быть:

AvoirCursus.objects.create (departement = dept, cursus = cursus)

?

Трудно что-то понять без трассировки стека.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...