我想用动态SQL创建一个触发器,从变量中获取列名。下面是我的简化mysql模式:
CREATE TABLE products (id int);
INSERT INTO products VALUES (1),(2);
CREATE TABLE attribute_values
(product_id int, `key` varchar(100), value varchar(100));
INSERT INTO attribute_values VALUES
( 1, 'title', 'Orange'),
( 1, 'code', 'O125'),
( 2, 'title', 'Pizza');
CREATE TABLE product_attributes
SELECT products.id,
MAX(CASE WHEN attribute_values.key = 'title' THEN attribute_values.value END) title,
MAX(CASE WHEN attribute_values.key = 'code' THEN attribute_values.value END) code
FROM products JOIN attribute_values ON products.id = attribute_values.product_id
GROUP BY products.id;
# trigger
DELIMITER //
CREATE PROCEDURE attribute_values_after_insert(IN product_id INT, IN column_name VARCHAR(100), IN val VARCHAR(100))
BEGIN
SET @sql = NULL;
SELECT concat('UPDATE product_attributes SET product_attributes.', column_name, '=', val, ' WHERE id=', product_id) INTO @sql;
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET @sql = NULL;
END//
DELIMITER ;
DELIMITER //
CREATE TRIGGER attribute_values_insert_trigger AFTER INSERT ON attribute_values FOR EACH ROW
BEGIN
CALL attribute_values_after_insert(NEW.product_id, NEW.key, NEW.value);
END
DELIMITER ;
http://sqlfiddle.com/#!9/674fd/1
即:
餐桌产品:
+-------------+
| id |
+-------------+
| 1 |
| 2 |
+-------------+
表属性值:
+-------------+----------+-----------+
| product_id | key | value |
+-------------+----------+-----------+
| 1 | title | Orange |
| 1 | code | O125 |
| 2 | title | Pizza |
+-------------+----------+-----------+
表产品属性:
+-------------+----------+-----------+
| id | title | code |
+-------------+----------+-----------+
| 1 | Orange | 0125 |
| 2 | Pizza | |
+-------------+----------+-----------+
在触发器中,我希望在插入到表attribute_values之后更新表product_attributes。
执行查询时:
INSERT INTO attribute_values VALUES (2, 'code', '0126');
我得到错误:
MySQL的查询面板中不允许使用DDL和DML语句;只允许SELECT语句。2将DDL和DML放在架构面板中。
在mysql中有解决这个问题的方法吗?
谢谢你的努力:)
1条答案
按热度按时间hk8txs481#
函数和触发器中的MySQL不支持动态插入但过程可以支持动态插入。
因此您可以在过程中进行更改,并在attribute_values表中插入查询。
INSERT INTO attribute_values VALUES(product_id,column_name,val);
然后你就可以调用过程
CALL attribute_values_after_insert(2,'code',132);