今天花了半天时间来研究mysql的存储过程函数和触发器的创建,觉得和oracle的大同小异,只是语法上更艰涩点,可能是先入为主吧,经过多次失败,终于创建成功,需要注意创建前要先执行“delimiter //”,创建后以“//”结束,还有就是怎么没有像plsql dev这样的工具来调试程序呢。和oracle的在语法上主要不同点有如下几方面:
1.declare放到了begin体里面
2.给变量复制是set xxx = 1
3. 在事务开始时要start transaction;
4.函数的返回是returns(oracle的是return),返回类型也需要给varchar等类型定义长度
还有就是在网上翻了个遍,手册也看了,就是没有找到存储过程的自定义异常,不知道到底有没有。
以下举几个例子:
没有create or replace语句,只要先删除再创建
delimiter$$
create function f_a(ai_n int)
returns varchar(64)
begin