存储触发器中更新表的执行查询问题 [英] Issue with execution query of update table in stored trigger

查看:78
本文介绍了存储触发器中更新表的执行查询问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试从PHP执行此自动生成查询,但无法正常工作

I'm trying to execute this auto generate query from PHP but it's not working

INSERT INTO mvt (id_piece, article_id_article, code_mvt, origine_mvt, type_mvt, code_art, des_art, qte_old, qte_mvt, qte_new, link_piece)
    SELECT 
        32,
        57,     
        'MVT/15/12/0001',
        'BSR/15/12/001',
        'S',
        'ART_039',
        'AAAA',
        a.qte_art,
        1,
        a.qte_art - 1,
        'uuuu'
    FROM article a
    WHERE a.id_article = 57

表的结构 mvt

CREATE TABLE IF NOT EXISTS `mvt` (
  `id_mvt` int(11) NOT NULL AUTO_INCREMENT,
  `id_piece` int(10) NOT NULL,
  `code_mvt` varchar(20) NOT NULL,
  `origine_mvt` varchar(100) NOT NULL,
  `date_mvt` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `type_mvt` varchar(20) NOT NULL,
  `article_id_article` int(10) unsigned NOT NULL,
  `code_art` varchar(20) NOT NULL,
  `des_art` varchar(255) NOT NULL,
  `qte_old` double NOT NULL,
  `qte_mvt` double NOT NULL,
  `qte_new` double NOT NULL,
  `link_piece` varchar(255) NOT NULL,
  PRIMARY KEY (`id_mvt`),
  KEY `article_id_article` (`article_id_article`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=229 ;

触发 mvt

DROP TRIGGER IF EXISTS `before_insert_mvt`;
DELIMITER //
CREATE TRIGGER `before_insert_mvt` BEFORE INSERT ON `mvt`
 FOR EACH ROW BEGIN
    UPDATE article  SET qte_art = NEW.qte_new WHERE id_article = NEW.article_id_article;
END

表结构商品

CREATE TABLE IF NOT EXISTS `article` (
  `id_article` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `famille_id_famille` int(10) unsigned NOT NULL,
  `marque_id_marque` int(10) unsigned NOT NULL,
  `tva_id_tva` int(10) unsigned NOT NULL,
  `code_art` varchar(20) DEFAULT NULL,
  `des_art` varchar(255) DEFAULT NULL,
  `paht_art` double DEFAULT NULL,
  `pamp_art` double DEFAULT NULL,
  `qte_art` double DEFAULT NULL,
  `seuil_alert` double NOT NULL,
  `seuil_reap` double NOT NULL,
  `date_modif` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `etat` int(11) NOT NULL DEFAULT '1',
  PRIMARY KEY (`id_article`),
  KEY `article_FKIndex1` (`tva_id_tva`),
  KEY `article_FKIndex2` (`marque_id_marque`),
  KEY `article_FKIndex3` (`famille_id_famille`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=82 ;

这是sql错误

 #1442 - Can't update table 'article' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.

它不起作用!
我缺少什么?

it doesn't work! What am I missing ?

推荐答案

触发器正在尝试更新要插入的同一表数据,这是不允许的。您可以使用临时表分两步进行操作。

The trigger is trying to update the same table that you're getting the inserted data from, and that's not allowed. You can do it in two steps with a temporary table.

CREATE TEMPORARY TABLE temp_mvt AS
SELECT 
    32,
    57,     
    'MVT/15/12/0001',
    'BSR/15/12/001',
    'S',
    'ART_039',
    'AAAA',
    a.qte_art,
    1,
    a.qte_art - 1,
    'uuuu'
FROM article a
WHERE a.id_article = 57;

INSERT INTO mvt SELECT * FROM temp_mvt;

DROP TABLE temp_mvt;

这篇关于存储触发器中更新表的执行查询问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆