Форум программистов, компьютерный форум, киберфорум
Python: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 23.09.2020
Сообщений: 4

Не могу отправить данные в MySql. Ошибка "Cannot add or update a child row: a foreign key constraint fails"

15.09.2023, 09:23. Показов 1190. Ответов 2

Студворк — интернет-сервис помощи студентам
нужно отправить список кортеже в бд, и у меня вот такая ошибка, что с ней делать?
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
for item in all_product: 
for items in item: 
name = items[0] 
address =  items[1] 
uuid = items[2] 
stock = items[3] 
id_citt = items[4] 
other_id = items[5] 
sale_date = items[6] 
print(id_citt) 
# Создаем кортеж для вставки в БД 
values_tuple = (id_citt, sale_date, stock, other_id) 
list_tumles.append(values_tuple) 
print(list_tumles) 
#print(values_tuple) 
insert_query = "INSERT INTO main_dnsshopavails (id, date, stock, product_id) VALUES (%s, %s, %s, %s) ON DUPLICATE KEY UPDATE date=VALUES(date), stock=VALUES(stock)" 
# Выполняем SQL-запрос 
 
db = MySQLdb.connect(host=DB_HOST, user=DB_USER, passwd=DB_PASSWORD, db=DB_NAME, connect_timeout=360) 
 
cursor = db.cursor() 
 
cursor.executemany(insert_query, list_tumles) 
 
print("Запрос успешно выполнен.") 
 
 
cursor.connection.commit() 
cursor.close() 
db.close()
MySQLdb.IntegrityError: (1452, 'Cannot add or update a child row: a foreign key constraint fails (`vsa777_crm2`.`main_dnsshopavails`, CONSTRAINT `main_dnsshopavails_shop_id_bec0428e_fk_ main_dnscityshops_id` FOREIGN KEY (`shop_id`) REFERENCES `main_dnscityshops` (`id`))')
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.09.2023, 09:23
Ответы с готовыми решениями:

Ошибка Cannot add or update a child row: a foreign key constraint fails
По заданию фк1 - EMPLOYEE (DEPARTMENT_ID) должен ссылаться на DEPARTMENT(ID), а фк2 - EMPLOYEE(CHIEF_ID) EMPLOYEE(ID). Я не понимаю в чем...

Ошибка MySQL: "Cannot add or update a child row: a foreign key constraint fails"
Доброе время суток!! Пытаюсь сделать такой запрос: ALTER TABLE `positions` ADD FOREIGN KEY (`pst_provider_id`) REFERENCES...

Cannot add or update a child row: a foreign key constraint fails
Здравствуйте! Изучая MySQL и PHP столкнулся с такой вот проблемкой: Cannot add or update a child row: a foreign key constraint fails...

2
 Аватар для kazak
3599 / 2741 / 354
Регистрация: 11.03.2009
Сообщений: 6,298
19.09.2023, 22:42
Цитата Сообщение от SHATAEV Посмотреть сообщение
что с ней делать?
начать с чтения книжек по БД
По ошибке срабатывает ограничение по внешнему ключу `shop_id`. По коду вы его не заполняете, возможно поэтому и срабатывает ограничении, данное поле не может быть NULL.
Какова структура таблиц `main_dnsshopavails` и `main_dnscityshops`?
0
0 / 0 / 0
Регистрация: 23.09.2020
Сообщений: 4
20.09.2023, 11:00  [ТС]
уф, я уже успел сам коекак разобраться. только все через 1 место. приходится брать shop_id из родительской таблицы и через сложный цикл сравнения добавлять их в свой список, и добавлял его в дочернюю таблицу
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
list_tumles = []
for item in all_product1:
    name = item[0]
    address =  item[1]
    uuid = item[2]
    stock = item[3]
    id_citt = item[4]
    other_id = item[5]
    date = item[6]
    idsh = item[7]
    print(id_citt)
    # Создаем кортеж для вставки в БД
    values_tuple = (date, stock, other_id, idsh)
    list_tumles.append(values_tuple)
print(list_tumles)
    #print(values_tuple)
insert_query = "INSERT INTO main_dnsshopavails (date, stock, product_id, shop_id) VALUES (%s, %s, %s, %s) ON DUPLICATE KEY UPDATE date=VALUES(date), stock=VALUES(stock)"
db = MySQLdb.connect(host=DB_HOST, user=DB_USER, passwd=DB_PASSWORD, db=DB_NAME, connect_timeout=360)
cursor = db.cursor()
cursor.executemany(insert_query, list_tumles)
 
print("Запрос успешно выполнен.")
 
 
cursor.connection.commit()
cursor.close()
db.close()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.09.2023, 11:00
Помогаю со студенческими работами здесь

Cannot add or update a child row: a foreign key constraint fails
Вот код ошибки: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrity ConstraintViolationException: Cannot add or update a child row: a...

Cannot add or update a child row: a foreign key constraint fails
Доброе время суток. Являюсь полнейшим профаном в MySql и в базах данных собственно тоже. Создавал базу данных и таблицы в mysql...

Cannot add or update a child row: a foreign key constraint fails
Всем привет. Буду рад помощи. Столкнулся с ошибкой. 123Cannot add or update a child row: a foreign key constraint fails...

Cannot add or update a child row: a foreign key constraint fails
Здравствуйте, имеется ИС Фондовая биржа. Собственно курсовая работа, написана не мной, я полный ноль. Проект старый 2013-2014г., написан...

Cannot add or update a child row: a foreign key constraint fails
Такая проблема: не добавляется значение в таблицу через запрос mysql_query. Если тоже самое делать через phpmyadmin - всё работает... ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru