Как создать триггер "автоинкремента" при обновлении в sql

Я хочу имитировать автоинкремент при обновлении счетчика строк.

Мой триггер:

CREATE DEFINER = CURRENT_USER TRIGGER `db`.`token_AFTER_UPDATE` AFTER UPDATE ON `token` FOR EACH ROW
BEGIN
  UPDATE `token` SET `counter` = `counter` + 1 WHERE `id` = NEW.id;
END

Но я получаю сообщение об ошибке:

1442 - Невозможно обновить «токен» таблицы в сохраненной функции / триггере, потому что он уже используется оператором, который вызвал эту сохраненную функцию / триггер.

Вам нужно расширить то, чего вы пытаетесь достичь здесь - я предполагаю, что удалить старую запись и добавить новую.

P.Salmon 04.07.2018 16:37
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
1
22
1

Ответы 1

Поскольку ваше описание недостаточно подробное для правильного ответа, возможно, вам поможет следующее:

Опция 1: Вы можете создать процедуру, которая выбирает наивысшее значение, добавляет 1 и обновляет последнюю обновленную строку.

Вариант 2: Если вы не используете эту таблицу в качестве ссылки, сделайте столбец AI PK и используйте «REPLACE INTO ...» вместо вставки / обновления.

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