WEB开发网
开发学院数据库MySQL 实际应用:MySQL5存储过程编写 阅读

实际应用:MySQL5存储过程编写

 2008-09-09 11:09:13 来源:WEB开发网   
核心提示: 5、存储过程或函数的调试:我目前还没有研究MySQL所带的各种工具包,还不清楚其提供了调试工具没有,实际应用:MySQL5存储过程编写(2),不过编译错误相对好查找;至于业务流程的调试,可以采用一个比较笨的方法,每次以相同的入参调用都会得到不同的加密结果, 算法相对比较简单,就是创建一个调

5、存储过程或函数的调试:我目前还没有研究MySQL所带的各种工具包,还不清楚其提供了调试工具没有,不过编译错误相对好查找;至于业务流程的调试,可以采用一个比较笨的方法,就是创建一个调试表,在包体中各个流程点都插入一条记录,以观察程序执行流程。这也是一个比较方便的笨办法。^_^

下面是2个例子,提供了一种字串加密的算法,每次以相同的入参调用都会得到不同的加密结果,

算法相对比较简单,不具备强度。分别以函数和过程的形式分别实现如下:

(1)函数

  eg:
/**/
set len=LENGTH(inpass);
if((len<=0) or (len>10)) then
return "";
end if;
  set offset=(SECOND(NOW()) mod 39)+1; /*根据秒数取模*/
/*insert into testtb values(offset,'offset: ');*/
set string_out='YN8K1JOZVURB3MDETS5GPL27AXWIHQ94C6F0#$_'; /*密钥*/
set string_in='_$#ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
  set outpass=CONCAT(outpass,SUBSTRING(string_out,offset,1));
/* insert into testtb values(2,outpass);*/
set string_out=CONCAT(string_out,string_out);
set @i=0;
REPEAT
set @i=@i+1;
set outpass=CONCAT(outpass,SUBSTR(string_out,INSTR(string_in,SUBSTRING
(inpass,@i,1))+offset,1));
/* insert into testtb values(@i+2,outpass);*/
UNTIL (@i>=len)
end REPEAT;
  return outpass;
END
  CREATE FUNCTION fun_addmm(inpass varchar(10)) RETURNS varchar(11)
  BEGIN
  declare string_in varchar(39);
  declare string_out varchar(78);
  declare offset tinyint(2);
  declare outpass varchar(30) default ';
  declare len tinyint;
  /*declare i tinyint;*/

(2)过程

Tags:实际 应用 MySQL

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接