MySQL和Oracle对比之存储过程

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 昨天晚上帮一个朋友处理了一个关于存储过程的问题,他需要迁移一些Oracle中的存储过程到MySQL中来,但是改了一部分的程序,发现MySQL中没法编译了,报了很多的错误。
+关注继续查看
昨天晚上帮一个朋友处理了一个关于存储过程的问题,他需要迁移一些Oracle中的存储过程到MySQL中来,但是改了一部分的程序,发现MySQL中没法编译了,报了很多的错误。
这个问题也比较典型,自己就趁热打铁总结了一下。
因为隐私的关系还有代码长度的关系,我就不罗列代码了。
假设Oracle中的存储过程如下,我们需要改写为MySQL代码:
set serveroutput on
CREATE or replace PROCEDURE test_proc( in_value IN varchar2)
as
 stmt_bz number;
 stmt_dml varchar2(200);
begin
stmt_bz:=100;
stmt_dml:=in_value||' insert into new_test(id,'
    || 'name)'
    || ' values('||stmt_bz||','||''''||stmt_bz||''''||')';
dbms_output.put_line(stmt_dml);
end;


exec test_proc('test');
运行情况如下:
SQL> exec test_proc('test');
test insert into new_test(id,name)values(100,'100')
PL/SQL procedure successfully completed.

看起来逻辑也不复杂,但是要迁移到MySQL中还是有不少的细节需要注意。
delimiter //
DROP PROCEDURE IF EXISTS `test_proc`//
CREATE PROCEDURE test_proc(IN in_value varchar(2000))
begin
  declare stmt_bz int;
  declare stmt_dml varchar(200);
  set stmt_bz=100;
  set stmt_dml=concat(' insert into new_test(id,'
    , 'name)'
    , 'values(',stmt_bz,',','''',stmt_bz,'''',')');
  select  stmt_dml;  
  end
//
delimiter ;
call test_proc('test');
输出结果如下:
mysql> call test_proc('test');
+-------------------------------------------------+
| stmt_dml                                        |
+-------------------------------------------------+
|  insert into new_test(id,name)values(100,'100') |
+-------------------------------------------------+
1 row in set (0.01 sec)

Query OK, 0 rows affected (0.01 sec)
第一处是分隔符的问题,delimiter 在MySQL在是可以自行制定的。我们暂定为//
第二处是关于drop procedure和create procedure,在Oracle中就可以直接制定为create or replace procedure
第三处是关于传入参数in_value,字符型传入参数在MySQL中就是varchar(2000),在Oracle就是varchar2 (注意不是varchar2(2000))
第四处是begin的部分,在Oracle中就是as begin来开启的,但是在MySQL就可以直接begin了。
第五处是声明变量在MySQL中就需要逐步声明,declare,但是在Oracle中是作为匿名pl/sql块一样来处理
第六处是变量初始化,在oracle中直接使用stmt_bz:=100; 但是在MySQL中需要用set stmt_bz=100;
第七处是关于字符串拼接,在MySQL中会用concat,在Oracle中可以使用||来拼接。
第八处就是输出变量,MySQL中使用
select  stmt_dml;  直接查询即可,在oracle可以调用dbms_output来输出。
第九处就是调用存储程序,在Oracle中使用exec,call都可以,在MySQL中只能使用call
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6天前
|
SQL Oracle 关系型数据库
选择适合您网站的 SQL 托管:MS SQL Server、Oracle、MySQL
如果您希望您的网站能够存储和检索数据,您的Web服务器应该能够访问使用SQL语言的数据库系统。以下是一些常见的SQL托管选项:
21 2
|
1月前
|
Oracle 关系型数据库 Java
Mybatis JdbcType与Oracle、MySql数据类型对应列表
Mybatis JdbcType与Oracle、MySql数据类型对应列表
|
1月前
|
SQL Oracle 关系型数据库
MySQL和Oracle的一些区别
MySQL和Oracle的一些区别
|
2月前
|
Oracle 关系型数据库 MySQL
OceanBase 数据库的企业版提供了 Oracle 到 MySQL 的迁移工具
OceanBase 数据库的企业版提供了 Oracle 到 MySQL 的迁移工具
49 2
|
3月前
|
SQL Oracle 关系型数据库
java实现oracle和mysql的group by分组功能|同时具备max()/min()/sum()/case when 函数等功能
java实现oracle和mysql的group by分组功能|同时具备max()/min()/sum()/case when 函数等功能
|
3月前
|
Oracle 关系型数据库 MySQL
Mysql 中函数ifnull()实现oracle nvl()函数
Mysql 中函数ifnull()实现oracle nvl()函数
|
3月前
|
Oracle 关系型数据库 MySQL
Oracle与MySQL的主键自增方式
Oracle与MySQL的主键自增方式
|
4月前
|
SQL Oracle 关系型数据库
Oracle与MySQL的分页查询sql语句格式
Oracle与MySQL的分页查询sql语句格式
|
4月前
|
SQL Oracle 关系型数据库
MySQL与Oracle 数据库中---> LPAD() 与 RPAD() 的使用
MySQL与Oracle 数据库中---> LPAD() 与 RPAD() 的使用
64 0
|
4月前
|
存储 Oracle 关系型数据库
连续天数的数据:Oracle 与 MySQL 查询技巧
连续天数的数据:Oracle 与 MySQL 查询技巧
65 0
推荐文章
更多
推荐镜像
更多