在下面的过程中,我想将title_id设置为@v_title_id变量,以便我可以在过程中使用它。任何想法都提前。我正在使用InnoDB引擎类型。
DELIMITER //
DROP PROCEDURE IF EXISTS sp_Title_SplitGenres //
CREATE PROCEDURE sp_Title_SplitGenres
(
p_genre_id INT,
p_genre_str VARCHAR(2000)
)
BEGIN
SET @v_stringseperator = '::::' ;
SET @v_title_id = (select title_id from filmo_title_genre where genre_id = p_genre_id);
WHILE LENGTH(TRIM( p_genre_str )) > 0
DO
SET @v_curr_Str := (SELECT SUBSTRING_INDEX( p_genre_str, @v_stringseperator, 1 ));
SET p_genre_str = (SELECT LTRIM(TRIM(LEADING CONCAT(@v_curr_Str ,@v_stringseperator) FROM p_genre_str)) );
create temporary table filmo_title_genre_temp
(
title_id int(11) NOT NULL,
genre_id int(11) NOT NULL,
sequence_num int(11) NOT NULL default '0',
PRIMARY KEY (title_id,genre_id,sequence_num)
)ENGINE = InnoDB;
while @v_title_id > 0
DO
select title_id,genre_id from filmo_title_genre where title_id = @v_title_id ;
END WHILE;
END WHILE;
REPLACE INTO filmo_title_genre
SELECT * FROM filmo_title_genre_temp;
drop table filmo_title_genre_temp;
delete from filmo_title_genre
where genre_id = p_genre_id;
END //
DELIMITER ;
答案 0 :(得分:0)
我不是一个mysql人(没看到那个标签直到我打开了这个),但我认为你想要使用 SELECT 而不是 SET 尝试从select语句设置变量。你正在把解析器弄成这个表操作。
SELECT @v_title_id := title_id from filmo_title_genre where genre_id = p_genre_id;