Как обновить новое значение в текущем поле и перенести текущее значение в старое поле?

У меня есть таблица MySQL, которая обновляется из API ежедневно, но теперь я хочу отслеживать конкретное поле, которое было обновлено из API. Я хочу обновить строку с текущим изменением поля (значения) и сохранить старое поле (значение) в другом поле. Может ли кто-нибудь, пожалуйста, указать мне правильное направление, и что будет лучшим для этого?

Стол (оригинал)

---------------------------------
|ID | Input Date | Expired Date |
---------------------------------
| 2 | 2017-05-17 | 2017-12-19   |   
---------------------------------
| 3 | 2017-07-09 | 2018-05-19   |
---------------------------------

Таблица при обновлении (текущая)

---------------------------------
|ID | Input Date | Expired Date |
---------------------------------
| 2 | 2017-05-17 | 2018-05-28   |  <----- ID 2: Expired Date updated
---------------------------------
| 3 | 2017-07-09 | 2018-05-19   |
---------------------------------

Таблица обновляется и сохраняет старое значение поля

------------------------------------------------
|ID | Input Date | Expired Date | Old Exp Date |
------------------------------------------------
| 2 | 2017-05-17 | 2018-05-28   | 2017-12-19   |  
------------------------------------------------    
| 3 | 2017-07-09 | 2018-05-19   |              | 
------------------------------------------------

Я надеюсь, что это имеет смысл немного, пожалуйста, помогите.. Большое спасибо:)

3 ответа

Вы можете создать триггер для него

CREATE TRIGGER date_updated BEFORE UPDATE ON <your table name>
       FOR EACH ROW SET <old exp date column> = OLD.<expired date column>

В PostgreSQL вы можете использовать предложение RETURNING

UPDATE <table name> SET <column> = <value> RETURNING <column>

Я нашел 2 способа сделать это:

А. Использование 2 запросов к базе данных
- обновить дату старого срока действия значением даты истечения срока действия из таблицы
- обновить дату истечения срока действия новым значением из API

Б. Использование одного запроса
- вы можете попробовать установить оба поля одновременно, но вы должны проверить это
- это как SET Old Exp Date = Expired date, Expired date = API_VALUE

Некоторые реализации не имеют одинаковый порядок UPDATE:
SQL-обновление-порядка из-оценки

Вы должны проверить его, чтобы увидеть, как он работает в вашей системе. Если это работает, вы должны решить, есть ли риск переносимости.

С уважением,
Lin

Вы можете просто попробовать запрос MySQL, подобный этому,

UPDATE your_table_name 
SET `Old Exp Date` = `Expired Date`, 
`Expired Date` = "$api_value";
Другие вопросы по тегам