【YashanDB知识库】共享从 MySQL异常处理CONTINUE HANDLER的改写方法

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 【YashanDB知识库】共享从 MySQL异常处理CONTINUE HANDLER的改写方法

MySQL的CONTINUE HANDLER
迁移MySQL业务时,遇到了MySQL的CONTINUE HANDLER FOR not found用法。详情如下:

-- 表DDL

create table t1(c1 int primary key, c2 int);

create table t2(c1 int primary key, c2 int);

-- 数据

insert into t1 values(1,1),(2,2);

insert into t2 values(1,11);

commit;

-- 使用CONTINUE HANDLER的存储过程

DELIMITER $$ CREATE PROCEDURE demo(IN p1 int) BEGIN DECLARE s bigint DEFAULT 0; DECLARE v1 bigint DEFAULT 0; DECLARE v2 bigint DEFAULT 0; DECLARE cur1 CURSOR FOR select c2 from t1 where c1=p1; DECLARE CONTINUE HANDLER FOR not found SET s=1; OPEN cur1; r_loop: LOOP IF s = 1 THEN LEAVE r_loop; END IF; -- 如果游标fetch结果not found,则设置s=1 FETCH cur1 INTO v1; IF s = 0 THEN -- 如果查询结果not found,则设置s=1 select c2 into v2 from t2 where c1=v1; -- 调试:输出v2值 select v2; -- 调试:输出s值 select s; END IF; END LOOP r_loop; CLOSE cur1; END$$

DELIMITER ;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
执行效果如下:

mysql> CALL DEMO(1);

+------+

| v2 |

+------+

| 11 |

+------+

1 row in set (0.00 sec)

+------+

| s |

+------+

| 0 |

+------+

1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

mysql> CALL DEMO(2);

+------+

| v2 |

+------+

| 0 |

+------+

1 row in set (0.00 sec)

+------+

| s |

+------+

| 1 |

+------+

1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

mysql> CALL DEMO(3);

Query OK, 0 rows affected (0.00 sec)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
YashanDB的改写方法

MySQL的CONTINUE HANDLER需要在YashanDB进行改写。改写原则:1)对于游标的执行,需要使用游标属性%notfound来改写;2)对于select语句的执行,则需要通过NO_DATA_FOUND的异常处理来改写。例如,以上示例的改写详情如下:

CREATE OR REPLACE PROCEDURE demo(p1 IN int) IS

s bigint DEFAULT 0;

v1 bigint DEFAULT 0;

v2 bigint DEFAULT 0;

CURSOR cur1 is select c2 from t1 where c1=p1;

BEGIN

OPEN cur1;

<<r_loop>>

LOOP

    IF s = 1 THEN

        EXIT r_loop;

    END IF;

    -- 如果游标fetch结果not found,则设置s=1

    FETCH cur1 INTO v1;

    IF cur1%notfound THEN

        s :=1 ;

    END IF;

    IF s = 0 THEN

        -- 如果查询结果not found,则设置s=1

        BEGIN

            select c2 into v2 from t2 where c1=v1;

        EXCEPTION

        WHEN NO_DATA_FOUND THEN

            s :=1 ;

        END;

        -- 调试:输出v2值

        DBMS_OUTPUT.PUT_LINE(v2);

        -- 调试:输出s值

        DBMS_OUTPUT.PUT_LINE(s);

    END IF;

END LOOP r_loop;

CLOSE cur1;

END;

/

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
YashanDB的执行效果
改写后的执行效果如下:

SQL> SET SERVEROUTPUT ON

SQL> CALL DEMO(1);

11

0

PL/SQL Succeed.

SQL> CALL DEMO(2);

0

1

PL/SQL Succeed.

SQL> CALL DEMO(3);

PL/SQL Succeed.

————————————————

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
9月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
1452 1
|
7月前
|
存储 关系型数据库 MySQL
MySQL数据库中进行日期比较的多种方法介绍。
以上方法提供了灵活多样地处理和对比MySQL数据库中存储地不同格式地日子信息方式。根据实际需求选择适当方式能够有效执行所需操作并保证性能优化。
685 10
|
8月前
|
SQL Oracle 关系型数据库
比较MySQL和Oracle数据库系统,特别是在进行分页查询的方法上的不同
两者的性能差异将取决于数据量大小、索引优化、查询设计以及具体版本的数据库服务器。考虑硬件资源、数据库设计和具体需求对于实现优化的分页查询至关重要。开发者和数据库管理员需要根据自身使用的具体数据库系统版本和环境,选择最合适的分页机制,并进行必要的性能调优来满足应用需求。
395 11
|
10月前
|
SQL 数据采集 关系型数据库
实现MySQL与SQL Server之间数据迁移的有效方法
总的来说,从MySQL到SQL Server的数据迁移是一个涉及到很多步骤的过程,可能会遇到各种问题和挑战。但只要精心规划、仔细执行,这个任务是完全可以完成的。
666 18
|
11月前
|
SQL 关系型数据库 MySQL
【MySQL】SQL分析的几种方法
以上就是SQL分析的几种方法。需要注意的是,这些方法并不是孤立的,而是相互关联的。在实际的SQL分析中,我们通常需要结合使用这些方法,才能找出最佳的优化策略。同时,SQL分析也需要对数据库管理系统,数据,业务需求有深入的理解,这需要时间和经验的积累。
367 12
|
11月前
|
SQL 关系型数据库 MySQL
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。
|
9月前
|
关系型数据库 MySQL
MySQL字符串拼接方法全解析
本文介绍了四种常用的字符串处理函数及其用法。方法一:CONCAT,用于基础拼接,参数含NULL时返回NULL;方法二:CONCAT_WS,带分隔符拼接,自动忽略NULL值;方法三:GROUP_CONCAT,适用于分组拼接,支持去重、排序和自定义分隔符;方法四:算术运算符拼接,仅适用于数值类型,字符串会尝试转为数值处理。通过示例展示了各函数的特点与应用场景。
|
11月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu系统的Docker上安装MySQL的方法
以上的步骤就是在Ubuntu系统的Docker上安装MySQL的详细方法,希望对你有所帮助!
1134 12
|
11月前
|
SQL 运维 关系型数据库
MySQL Binlog 日志查看方法及查看内容解析
本文介绍了 MySQL 的 Binlog(二进制日志)功能及其使用方法。Binlog 记录了数据库的所有数据变更操作,如 INSERT、UPDATE 和 DELETE,对数据恢复、主从复制和审计至关重要。文章详细说明了如何开启 Binlog 功能、查看当前日志文件及内容,并解析了常见的事件类型,包括 Format_desc、Query、Table_map、Write_rows、Update_rows 和 Delete_rows 等,帮助用户掌握数据库变化历史,提升维护和排障能力。
|
10月前
|
缓存 JSON 关系型数据库
MySQL 查询优化分析 - 常用分析方法
本文介绍了MySQL查询优化分析的常用方法EXPLAIN、Optimizer Trace、Profiling和常用监控指标。

推荐镜像

更多