Обновить дубликат ключа в скрипте php

Я создал уникальный индекс в своей таблице для page_id и display_id, но у меня возникают проблемы с синтаксисом PHP при выполнении повторного вызова обновления ключа.

Это sql-запрос в моем php-скрипте:

$assignPage = "
INSERT INTO display_to_page (page_id, display_id)
VALUES ( '".$pageID."', '".$displayID."')
ON DUPLICATE KEY UPDATE
active = 1
";

Но он не передает синтаксис в части ON DUPLICATE KEY.

Я просто хочу сказать (вставьте это, но если ключ page_id / display_id существует, обновите, установив для активного столбца значение 1)

Я здесь что-то не так делаю?

Вы делаете много неправильных. Это не то, как строить запрос. Используйте заранее подготовленные операторы, иначе у вас будут всевозможные проблемы.

miken32 27.09.2018 04:50
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
1
54
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

При объединении строк произошла ошибка, поэтому я ее упростил.

$assignPage = "INSERT INTO display_to_page (page_id, display_id)
                VALUES ( '$pageID', '$displayID')
                ON DUPLICATE KEY UPDATE active = 1";

You should also use prepared parameterized statements in either the MYSQLI_ or PDO API's rather than value concatenation.

Спасибо, мне действительно не нужен НАБОР? Потому что, казалось, работало и без него

Whisou138 27.09.2018 01:29

Да, я понял свою ошибку там и убрал ее из своего ответа

RiggsFolly 27.09.2018 01:29

@ miken32 Хм, ну, теперь мне еще:?

RiggsFolly 27.09.2018 10:00

Другие вопросы по теме