http://blog.itpub.net/559237/viewspace-438942/

今天花了半天时间来研究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  declare vs_res varchar(64);  declare vi_count int;  select max(n),count(1)  into vs_res ,vi_count from d where i = ai_n;  if vs_res is null then   set vs_res = '';  end if;  return vs_res; end$$ DELIMITER ;

如果出现如下错误,需要设置set global log_bin_trust_function_creators=TRUE。 ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)

mysql> select f_a(1); +--------+ | f_a(1) | +--------+ | 直播   | +--------+ 1 row in set (0.05 sec)

存储过程: delimiter$$

create procedure p_a(in ai_num int)  begin  declare vi_loop int default 0;  declare vi_maxid,vi_count int;   select max(id),count(1) into vi_maxid,vi_count from a;  if vi_count = 0 then   set vi_maxid = 0;  end if;  start transaction;  set vi_loop = 1;  while vi_loop < ai_num do          set vi_maxid = vi_maxid + 1;   insert into u values(vi_maxid,vi_maxid);   set vi_loop = vi_loop + 1;  end while;  commit;  end$$

delimiter$$

delimiter $$

create procedure curdemo() begin   declare done int default 0;   declare a char(16);   declare b,c,d int;   declare cur1 cursor for select id,data from test.t1;   declare cur2 cursor for select i from test.t2;   declare continue handler for sqlstate '02000' set done = 1;   open cur1;   open cur2;   repeat     fetch cur1 into a, b;     fetch cur2 into c;     if not done then        set d = sign(b - c);        case d         when 0 then               insert into test.t3 values (a,0);         when 1 then               insert into test.t3 values (a,b);         when -1 then               insert into test.t3 values (a,c);        end case;     end if;   until done end repeat;   close cur1;   close cur2; end$$ delimiter; 触发器: 和oracle差不多,就是需要开头delimiter //,结尾用//,new前的:去掉即可。 mysql> drop trigger trg_a mysql> delimiter // mysql> create trigger trg_a before insert on a       -> for each row

-> insert into b set id=new.id,i=111;     -> delete from c where a=new.id;     -> end;     -> // Query OK, 0 rows affected (0.02 sec)

运行过程 msql>call p_a(1000); 通过show create procedure/function name可以查看过程和函数的结果 如mysql>show create procedure p_a;

####以下是项目中的例子

drop FUNCTION `manage`.`f_getarea`; DELIMITER $$

CREATE FUNCTION `manage`.`f_getarea`(as_areaid  varchar(32), ai_i   int)  #ai_i层数  #select f_getarea('1.22.333.55',2) can get '1.22.'  RETURNS varchar(32)  BEGIN   declare vi_temp,vi_i,vi_instr tinyint(2);     #不可能超过5层    if ai_i > 5 or ai_i < 1 then     return '';   end if;   set vi_temp = 0,vi_i = 0;   while 1 = 1 do         set vi_instr = vi_temp;  set vi_temp = locate('.',as_areaid,vi_temp+1);         if vi_temp = 0 then   return substr(as_areaid,1,vi_instr);  end if;         if vi_i = ai_i then   return substr(as_areaid,1,vi_instr);         end if;  set vi_i = vi_i + 1;   end while;   return '';  END$$

DELIMITER ;

mysql存储过程、函数和触发器的创建 [转]的更多相关文章

  1. MySQL mysqldump 导入/导出 结构&数据&存储过程&函数&事件&触发器

    ———————————————-库操作———————————————-1.①导出一个库结构 mysqldump -d dbname -u root -p > xxx.sql ②导出多个库结构 m ...

  2. MySQL 存储过程 函数 routine 权限

    MySQL 存储过程 函数 routine 权限 Table of Contents 1. mysql存储过程/函数权限 1.1. 相关对象操作权限检查 1.2. 执行权限 1 mysql存储过程/函 ...

  3. MySQL自定义函数、触发器、存储过程

    存储过程 概念 存储过程,是一个数据库对象,类似一个函数. 在存储过程中可以使用SQL中的绝大部分内容,并且可以加入编程语言的特性(循环判断分支). 编写好存储过程之后,可以在客户端调用存储过程,存储 ...

  4. mysql 存储过程 函数 触发器

    mysql存储过程与函数 存储过程下载  demo mysql> delimiter // -- 这里//为修改默认分隔符: mysql> CREATE PROCEDURE simplep ...

  5. mysql使用存储过程&函数实现批量插入

    写这边文章的目的,是想结合mysql 存储过程+函数完成一个批量删除的功能吧...正好也好加深下对procedure和function的熟练操作吧...废话不多说,我就直接上表结构啦哈,如下: cre ...

  6. Paip.断点调试MYSQL存储过程跟函数的解决方案大法

    Paip.断点调试MYSQL存储过程跟函数的解决方案大法 作者Attilax ,  EMAIL:1466519819@qq.com  来源:attilax的专栏 地址:http://blog.csdn ...

  7. MySQL主从环境下存储过程,函数,触发器,事件的复制情况

    下面,主要是验证在MySQL主从复制环境下,存储过程,函数,触发器,事件的复制情况,这些确实会让人混淆. 首先,创建一张测试表 mysql),age int); Query OK, rows affe ...

  8. MySQL 第十天(视图、存储过程、函数、触发器)

    MySql高级-视图.函数.存储过程.触发器 目录 一.视图    1 1.视图的定义    1 2.视图的作用    1 (1)可以简化查询.    1 (2)可以进行权限控制,    3 3.查询 ...

  9. Mysql 存储过程、函数、触发器和视图的权限检查

    当存储过程.函数.触发器和视图创建后,不单单创建者要执行,其它用户也可能需要执行,换句话说,执行者有可能不是创建者本身,那么在执行存储过程时,MySQL是如何做权限检查的? 在默认情况下,MySQL将 ...

随机推荐

  1. C#判断程序是否以管理员身份运行,否则以管理员身份重新打开

    /// <summary> /// 判断程序是否是以管理员身份运行. /// </summary> public static bool IsRunAsAdmin() { Wi ...

  2. (转)解析php中die(),exit(),return的区别

    本篇文章是对php中die(),exit(),return的区别进行了详细的分析介绍,需要的朋友参考下     die()停止程序运行,输出内容exit是停止程序运行,不输出内容return是返回值d ...

  3. (转)用eclipse创建一个j2ee的web工程后,左面projects窗口中的项目如何没有显示webRoot文件夹,除了src的文件夹,其他都不显示

    左边目录窗口的右上方,有个向下的箭头,点里面的filters,把所有的勾都去掉看看

  4. WCF调用问题

    1---WCF常用的节点绑定 basicHttpBinding和netTcpBinding 当通过Spring对象注入 如 WCFForOrderService 对象注入 public WCFForO ...

  5. Android Studio 打开弹出警告框

    1.Android Studio打开后,自己的项目没有打开,就弹出了警告框,重启之后依然弹出警告框: 警告框内容:"Cannot load project: java.lang.Illega ...

  6. Hbase常用操作

    下面我们看看HBase Shell的一些基本操作命令,我列出了几个常用的HBase Shell命令,如 名称 命令表达式 创建表 create '表名称', '列名称1','列名称2','列名称N' ...

  7. Android studio 开发环境搭建

    Android studio 开发环境搭建 一.环境: 下载java jdk:http://www.oracle.com/technetwork/cn/java/javase/downloads/jd ...

  8. PHPCMSV9 更换域名后,要做的操作

    修改/caches/configs/system.php里面所有和域名有关的,把以前的老域名修改为新域名. 进入后台设置-->站点管理,对相应的站点的域名修改为新域名. 点击后台右上角的&quo ...

  9. 怎么加sudo权限

    安装好Debian后还不能使用sudo如果没有安装sudo,则在root用户下apt-get install sudo在root设置sudoers配制文件chmod +w /etc/sudoersvi ...

  10. PreparedStatement執行sql語句

    import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import org ...