Задать вопрос
@reeder

Как правильно пользоваться 'ON DUPLICATE KEY UPDATE'?

Привет всем. Я столкнулся с проблемой:
SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '43117-series' for key 'titles_tmdb_id_type_unique' SQL:
INSERT INTO titles 
    (title,language,country,updated_at,tmdb_id,type) 
VALUES 
    (Teen Choice Awards, En, US, 2015-05-01 01:44:14, 43117,series) 
ON DUPLICATE KEY UPDATE 
title = values(title), 
language = values(language), 
country = values(country), 
updated_at = values(updated_at), 
tmdb_id = values(tmdb_id),
type = values(type)


Помогите найти решения!

Структура таблицы такая:
CREATE TABLE IF NOT EXISTS `titles` (
  `id` bigint(20) unsigned NOT NULL,
  `title` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `type` varchar(15) COLLATE utf8_unicode_ci NOT NULL DEFAULT 'movie',
....
  `tmdb_id` bigint(20) unsigned DEFAULT NULL,
....
  `updated_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
  `language` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  `country` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

ALTER TABLE `titles`
  ADD PRIMARY KEY (`id`),
  ADD UNIQUE KEY `titles_tmdb_id_type_unique` (`tmdb_id`,`type`);

ALTER TABLE `titles`
  MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT;
  • Вопрос задан
  • 635 просмотров
Подписаться 1 Оценить Комментировать
Пригласить эксперта
Ответы на вопрос 1
mgyk
@mgyk
Уберите
tmdb_id = values(tmdb_id),
type = values(type)


из запроса, они и так уже совпали
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

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