Мой вопрос может быть простым для вас, если вы привыкли к MySQL. Я привык к PostgreSQL SGBD, и я пытаюсь перевести PL/PgSQL script в MySQL.
Вот что у меня есть:
delimiter //
CREATE TRIGGER pgl_new_user
AFTER INSERT ON users FOR EACH ROW
BEGIN
DECLARE m_user_team_id integer;
SELECT id INTO m_user_team_id FROM user_teams WHERE name = "pgl_reporters";
DECLARE m_projects_id integer;
DECLARE cur CURSOR FOR SELECT project_id FROM user_team_project_relationships WHERE user_team_id = m_user_team_id;
OPEN cur;
ins_loop: LOOP
FETCH cur INTO m_projects_id;
IF done THEN
LEAVE ins_loop;
END IF;
INSERT INTO users_projects (user_id, project_id, created_at, updated_at, project_access)
VALUES (NEW.id, m_projects_id, now(), now(), 20);
END LOOP;
CLOSE cur;
END//
Но MySQL Workbench дает мне ошибку на DECLARE m_projects_id
. Я действительно не понимаю, потому что у меня есть одна и та же инструкция на две строки выше...
Любые подсказки?
EDIT: neubert решил эту ошибку. Благодарю.
Но при попытке вставить в пользователя:
Error Code: 1329. No data - zero rows fetched, selected, or processed
Есть ли у вас идеи? Или лучше, знаете ли вы, как я могу получить лучшее сообщение об ошибке?