• ADADADADAD

    mysql和Oracle游标的用法[ mysql数据库 ]

    mysql数据库 时间:2024-11-28 13:03:22

    作者:文/会员上传

    简介:

    使用游标根据一个表中的数据,循环创建不同的表mysql中的DELIMITER $$DROP PROCEDURE IF EXISTS zy.jk_jkzl_political_location_pro $$CREATE PROCEDURE zy.jk_jkzl_politica

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    使用游标根据一个表中的数据,循环创建不同的表

    mysql中的

    DELIMITER $$
    DROP PROCEDURE IF EXISTS zy.jk_jkzl_political_location_pro $$
    CREATE PROCEDURE zy.jk_jkzl_political_location_pro()
    BEGIN
    DECLARE no_more_pro INT DEFAULT 0;
    DECLARE num VARCHAR(20);
    #一 声明一个游标
    DECLARE cursor_create_user CURSOR FOR SELECT area_code FROM zy.jk_jkzl_political_location;
    #二 声明一个处理异常的信息
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_more_pro=1;
    #三 打开游标
    OPEN cursor_create_user;
    #四 给游标赋值
    FETCH NEXT FROM cursor_create_user INTO num;
    #五 准配重复调用游标的信息
    REPEAT
    SET @sql=CONCAT('create table zy.tf_f_user_p',num,'(user_name varchar(20),user_state int)engine=innodb default charset=utf8');
    SELECT NOW();
    PREPARE create_sql FROM @sql;
    EXECUTE create_sql;
    DEALLOCATE PREPARE create_sql;
    FETCH NEXT FROM cursor_create_user INTO num; #####必须标明,否则循环失败
    UNTIL no_more_pro=1 #调用所有游标数据
    END REPEAT; #关闭重复调用
    CLOSE cursor_create_user; #关闭游标
    END;

    Oracle 的测试:

    DELIMITER $$
    DROP PROCEDURE IF EXISTS zy.jk_jkzl_political_location_pro $$
    CREATE PROCEDURE zy.jk_jkzl_political_location_pro()
    BEGIN
    DECLARE no_more_pro INT DEFAULT 0;
    DECLARE num VARCHAR(20);
    #一 声明一个游标
    DECLARE cursor_create_user CURSOR FOR SELECT area_code FROM zy.jk_jkzl_political_location;
    #二 声明一个处理异常的信息
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_more_pro=1;
    #三 打开游标
    OPEN cursor_create_user;
    #四 给游标赋值
    FETCH NEXT FROM cursor_create_user INTO num;
    #五 准配重复调用游标的信息
    REPEAT
    SET @sql=CONCAT('create table zy.tf_f_user_p',num,'(user_name varchar(20),user_state int)engine=innodb default charset=utf8');
    SELECT NOW();
    PREPARE create_sql FROM @sql;
    EXECUTE create_sql;
    DEALLOCATE PREPARE create_sql;
    FETCH NEXT FROM cursor_create_user INTO num;
    UNTIL no_more_pro=1 #调用所有游标数据
    END REPEAT; #关闭重复调用
    CLOSE cursor_create_user; #关闭游标
    END;

    mysql和Oracle游标的用法.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: mysqloracle