错误#1242更新时子查询返回多于1行

时间:2013-08-31 13:07:02

标签: mysql sql triggers sql-update

这是我以前的question。我无法解决问题。我更新了我的代码,并间接使用GROUP BY。但同样的问题表明。子查询返回重复值。实际上我做了一个TRIGGER,所以我认为如果显示触发器,它将很清楚理解

--
-- Triggers `product_purchases`
--
DROP TRIGGER IF EXISTS `change_stock_when_purchases`;
DELIMITER //
CREATE TRIGGER `change_stock_when_purchases` AFTER INSERT ON `product_purchases`
 FOR EACH ROW BEGIN
  DECLARE X INTEGER;
  SET X = (SELECT product_size FROM product_stock WHERE product_id = NEW.product_id );
  IF NEW.product_size =X  THEN
    UPDATE
        product_stock as S1
        INNER JOIN
        (
        SELECT
            S.product_stock_id,I.quantity 
        FROM 
            product_stock AS S
        INNER JOIN
            product_purchase_item AS I 
        ON
            S.product_id=I.product_id AND S.product_size=I.product_size
        INNER JOIN
            product_purchases AS P
        ON
            I.product_purchase_item_id=P.product_purchase_item_id
        WHERE
            P.product_purchase_id=NEW.product_purchase_id
        GROUP BY 
            S.product_stock_id
        )
        AS M
    ON 
        S1.product_stock_id=M.product_stock_id
    SET
        S1.product_size_quantity=S1.product_size_quantity+M.quantity;
    ELSE
    INSERT INTO
        product_stock (product_id,product_size,product_size_quantity)
        SELECT
            product_id,product_size, quantity
        FROM
            product_purchase_item
        WHERE
            product_purchase_item_id=NEW.product_purchase_item_id;
  END IF;
END
//
DELIMITER ;

product_id

上更新同一product_sizeproduct_stock时出现问题

1 个答案:

答案 0 :(得分:2)

代码中最可疑的子查询就是这个:

SET X = (SELECT product_size FROM product_stock WHERE product_id = NEW.product_id );

product_stock表中是否有重复项?这很容易确定:

select product_id
from product_stock
group by product_id
having count(*) > 1;

如果这样做,您可以选择其中一个:

SET X = (SELECT product_size FROM product_stock WHERE product_id = NEW.product_id limit 1);