INSERT оператор конфликтует с внешним ключом

Очень простой подход, не зависящий от версии python, отсутствовал в уже заданных ответах, которые вы можете использовать большую часть времени (по крайней мере, я):

new_list = my_list * 1       #Solution 1 when you are not using nested lists

Однако, если my_list содержит другие контейнеры ( например, вложенных списков), вы должны использовать функцию глубокой печати, как другие, предложенные в ответах выше, из библиотеки копий. Например:

import copy
new_list = copy.deepcopy(my_list)   #Solution 2 when you are using nested lists

.Bonus: Если вы не хотите копировать элементы, используйте (ака мелкой копии):

new_list = my_list[:]

Давайте понимать разницу между решением # 1 и Solution # 2

>>> a = range(5)
>>> b = a*1
>>> a,b
([0, 1, 2, 3, 4], [0, 1, 2, 3, 4])
>>> a[2] = 55 
>>> a,b
([0, 1, 55, 3, 4], [0, 1, 2, 3, 4])

Как вы можете видеть, решение № 1 отлично работало, когда мы не использовали вложенные списки. Давайте проверим, что произойдет, когда мы применим решение №1 к вложенным спискам.

>>> from copy import deepcopy
>>> a = [range(i,i+4) for i in range(3)]
>>> a
[[0, 1, 2, 3], [1, 2, 3, 4], [2, 3, 4, 5]]
>>> b = a*1
>>> c = deepcopy(a)
>>> for i in (a, b, c): print i   
[[0, 1, 2, 3], [1, 2, 3, 4], [2, 3, 4, 5]]
[[0, 1, 2, 3], [1, 2, 3, 4], [2, 3, 4, 5]]
[[0, 1, 2, 3], [1, 2, 3, 4], [2, 3, 4, 5]]
>>> a[2].append('99')
>>> for i in (a, b, c): print i   
[[0, 1, 2, 3], [1, 2, 3, 4], [2, 3, 4, 5, 99]]
[[0, 1, 2, 3], [1, 2, 3, 4], [2, 3, 4, 5, 99]]   #Solution#1 didn't work in nested list
[[0, 1, 2, 3], [1, 2, 3, 4], [2, 3, 4, 5]]       #Solution #2 - DeepCopy worked in nested list
0
задан marc_s 24 March 2019 в 07:08
поделиться

2 ответа

Можете ли вы предоставить выполненный запрос вставки? убедитесь, что значение, которое вы вставляете в столбец, который ссылается на другую таблицу, существует в этой таблице. то есть в вашей таблице примеров, если вы вставляете в таблицу фильмов, DirctorID должно существовать в истории Director.

0
ответ дан student 24 March 2019 в 07:08
поделиться

Поскольку у вас нет данных в таблице директора, вы не можете выполнить запись в таблицу фильмов (из-за ссылки на внешний ключ), поэтому сначала введите некоторые данные в таблицу директора, затем введите данные в таблицу фильмов

[112 ] Подробнее см. По этой ссылке Оператор INSERT конфликтует с ограничением FOREIGN KEY - SQL Server

0
ответ дан Praveen Panishetti 24 March 2019 в 07:08
поделиться
Другие вопросы по тегам:

Похожие вопросы: