Mysql, как добавить вычисляемый столбец для вычисления суммы столбца json?

Столбец a содержит массив json, отформатированный как [1,4,3,6]

Я хочу, чтобы столбец b был суммой столбца a.

ALTER TABLE `T` ADD `b` int AS 
        (SELECT SUM(t.c) FROM JSON_TABLE(a, '$[*]' COLUMNS (c INT PATH '$')) AS t) NULL;

1064 - У вас есть ошибка в синтаксисе SQL; проверьте руководство, соответствующее версии вашего сервера MySQL, на предмет правильного синтаксиса для использования рядом с 'SELECT SUM(t.c) FROM JSON_TABLE(a, '$[*]' COLUMNS (c INT PATH '$')) AS t) NULL' в линия 1

Возможно, стоит взглянуть на триггеры здесь, alter table делает что-то со столбцами один раз, а не тогда, когда происходит событие (например, вставка, обновление и т. д.).

Can O' Spam 12.04.2023 16:47

работает ли выбор и дает ли ожидаемый результат?

P.Salmon 12.04.2023 17:19
Освоение архитектуры микросервисов с 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
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
1
2
50
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

В этом разделе документов MySQL указаны правила для сгенерированных столбцов. Наиболее актуальными здесь кажутся два:

  • Допускаются литералы, детерминированные встроенные функции и операторы.
  • Подзапросы не допускаются.

Вы можете добиться «аналогичной» функциональности с помощью пары триггеров:

DELIMITER $$

CREATE TRIGGER `test_t_b_insert` BEFORE INSERT ON `t`
  FOR EACH ROW BEGIN
    SET NEW.b = (SELECT SUM(t.c) FROM JSON_TABLE(NEW.a, '$[*]' COLUMNS (c INT PATH '$')) AS t);
  END$$

CREATE TRIGGER `test_t_b_update` BEFORE UPDATE ON `t`
  FOR EACH ROW BEGIN
    IF NOT OLD.a <=> NEW.a THEN
        SET NEW.b = (SELECT SUM(t.c) FROM JSON_TABLE(NEW.a, '$[*]' COLUMNS (c INT PATH '$')) AS t);
    END IF;
  END$$

DELIMITER ;

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