#mysql #sql
#mysql #sql
Вопрос:
У меня есть код, который уже работает, но я ищу способ написать инструкцию sql, которая вставляет в таблицу, когда строка была удалена из другой таблицы, без необходимости перечислять каждый столбец в качестве значения в инструкции insert. Для случаев, когда в таблице много столбцов, это действительно пригодится. Вот мой текущий код, я надеюсь, что кто-нибудь может помочь мне его модифицировать.
CREATE TABLE `history_tblvendorpayment` LIKE `tblvendorpayment`;
ALTER TABLE `history_tblvendorpayment`
MODIFY COLUMN `id` INT UNSIGNED NOT NULL;
ALTER TABLE `history_tblvendorpayment` DROP PRIMARY KEY;
ALTER TABLE `history_tblvendorpayment`
ADD COLUMN `history_id` INT UNSIGNED NOT NULL;
ALTER TABLE `history_tblvendorpayment`
ADD CONSTRAINT PRIMARY KEY (`history_id`);
ALTER TABLE `history_tblvendorpayment`
MODIFY `history_id` INT UNSIGNED NOT NULL AUTO_INCREMENT;
DELIMITER $
DROP TRIGGER `delete_tblvendorpayment`$
CREATE TRIGGER `delete_tblvendorpayment` BEFORE DELETE on `tblvendorpayment`
FOR EACH ROW
BEGIN
INSERT INTO history_tblvendorpayment (id, created_by,
vendor_id, amount_payable,
amount_payed, description,
depositor_name, gl_code_credit,
gl_code_debit, txn_date,
pay_date, ref_id,
bank, currency,
date, md_approval,
status, sage_status,
memo_id)
VALUES (
OLD.id, OLD.created_by,
OLD.vendor_id, OLD.amount_payable,
OLD.amount_payed, OLD.description,
OLD.depositor_name, OLD.gl_code_credit,
OLD.gl_code_debit, OLD.txn_date,
OLD.pay_date, OLD.ref_id,
OLD.bank, OLD.currency,
OLD.date, OLD.md_approval,
OLD.status, OLD.sage_status,
OLD.memo_id
);END$
DELIMITER ;
Я надеюсь на что-то вроде этого:
DELIMITER $
DROP TRIGGER `delete_tblvendorpayment`$
CREATE TRIGGER `delete_tblvendorpayment` BEFORE DELETE on `tblvendorpayment`
FOR EACH ROW
BEGIN
INSERT INTO history_tblvendorpayment
SELECT * FROM OLD;
END$
DELIMITER ;
Ответ №1:
Если вы вставляете все столбцы из исходной таблицы, вы можете упростить триггер до:
CREATE TRIGGER `delete_tblvendorpayment` BEFORE DELETE on `tblvendorpayment`
FOR EACH ROW
BEGIN
INSERT INTO history_tblvendorpayment
SELECT *
FROM tblvendorpayment
WHERE id = OLD.id;
END
Комментарии:
1. извините, что это вызвано моими определениями таблиц. Все работает нормально. Спасибо