0

データベースで次の手順を正常に定義しましたが、どういうわけか期待どおりに機能しません。

CREATE PROCEDURE `mod_prefer`(IN sid INT)
BEGIN
declare s1 int;
declare s2 int;
SELECT SUM(c_load) INTO s1 FROM course WHERE id IN (SELECT course_id FROM prefer WHERE staff_id = sid) AND sem = 1;
SELECT SUM(c_load) INTO s2 FROM course WHERE id IN (SELECT course_id FROM prefer WHERE staff_id = sid) AND sem = 2;
IF s1>s2 THEN
UPDATE staff SET sem = 1 WHERE id = sid;
ELSE
UPDATE staff SET sem = 2 WHERE id = sid;
END IF;
END

上記の手順は、次のようにトリガーを使用して呼び出されます (挿入後のトリガーです)。

CALL mod_prefer(new.staff_id);

その結果sem、指定されたスタッフ メンバーの値を設定する代わりに、ロジックがどのように機能するかに関係なく、つまり、sem の値が実際には 1 であっても、手順はすべての sem 値を 2 に更新します。

助けてください。

4

1 に答える 1

0

このコードを試してください -

SELECT
  SUM(IF(sem = 1, c_load, NULL)), SUM(IF(sem = 2, c_load, NULL)) s2
  INTO s1, s2
FROM course c
  JOIN prefer p
    ON p.course_id = c.id
  WHERE staff_id = sid;

UPDATE staff SET sem = IF(s1 > s2, 1, 2) WHERE id = sid;
于 2012-09-26T07:02:27.423 に答える