Автоматическое увеличение типа столбца в mysql

id  animal      type    value

1   Dog           Land  11
2   Fish        Water   102
3   Horse       Land    12
4   Duck        Water   104
5   Crocodile   Water   105
6   Donkey      Land    13
7   Buffalo     Land    14

как увеличить значение, если вставить еще одну запись, когда type=land оно увеличится до 15 а также

вставляется еще одна запись, когда type=water она увеличится до 106 пожалуйста, дайте мне знать

Используете ли вы какой-либо язык программирования вместе с mysql?

nice_dev 03.05.2019 14:15

нет не пользуюсь

joe 03.05.2019 14:16

Хорошо, тогда как вы вставляете эти значения? Вы откуда-то это получаете?

nice_dev 03.05.2019 14:20
Освоение архитектуры микросервисов с 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
3
19
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Не материализуйте это. Это влечет за собой серьезный риск того, что данные станут несогласованными. Используйте представление, получающее количество в подзапросе.

ALTER TABLE elbat
            DROP value;

CREATE VIEW elbat_with_value
AS
SELECT t1.id,
       t1.animal,
       (SELECT count(*)
               FROM elbat t2
               WHERE t2.id <= t1.id
                     AND t2.type = t1.type) value
       FROM elbat t1;

Или в версии MySQL 8 вы могли бы использовать row_number().

ALTER TABLE elbat
            DROP value;

CREATE VIEW elbat_with_value
AS
SELECT t1.id,
       t1.animal,
       row_number() OVER (PARTITON BY t1.type
                          ORDER BY t1.id) value
       FROM elbat t1;

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