Я создал хранимую процедуру в MySQL, используя следующий синтаксис.
DROP PROCEDURE IF EXISTS `sp-set_comment_count`;
DELIMITER $$
CREATE PROCEDURE `sp_set-comment_count` (IN _id INT)
BEGIN
-- AC - AllCount
DECLARE AC INT DEFAULT 0;
SELECT COUNT(*) AS ac
INTO AC
FROM usergroups AS ug
LEFT JOIN usergroup_comments AS ugm ON ugm.`gid` = ug.`id`
LEFT JOIN mediagallery AS dm ON ugm.mid = dm.`id`
WHERE dm.`status` NOT IN (200, 201, 202, 203, 204, 205)
AND ug.`id` = _id;
UPDATE usergroups
SET allCount = AC,
WHERE usergroups.`id` = _id;
END $$
DELIMITER ;
К вашему сведению, я значительно упростила хранимую процедуру, но знаю, что она работает без проблем.
Я хотел бы иметь возможность настроить триггер из usergroup_comments, который работает следующим образом.
DROP TRIGGER IF EXISTS `usergroups_comments_insert`
CREATE TRIGGER `usergroups_comments_insert` AFTER INSERT ON `usergroups_comment`
FOR EACH ROW
BEGIN
CALL sp-set-comment_count(NEW.`gid`);
END;
Но по какой-то причине каждый раз, когда я делаю это, mysql выдает ошибку, которая не очень полезна, так как в строке 4 есть синтаксическая ошибка.
Я просмотрел документацию по mysql и нашел некоторую информацию об ограничениях триггеров, но нашел ее довольно запутанной.
http://dev.mysql.com/doc/refman/5.1/en/stored-program-restrictions.html
Любые идеи будут полезны.