存储过程

时间:2010-01-12 05:59:01

标签: mysql stored-procedures

在下面的过程中,我想将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 ;

1 个答案:

答案 0 :(得分:0)

我不是一个mysql人(没看到那个标签直到我打开了这个),但我认为你想要使用 SELECT 而不是 SET 尝试从select语句设置变量。你正在把解析器弄成这个表操作。

SELECT @v_title_id := title_id from filmo_title_genre where genre_id = p_genre_id;