Welcome 微信登录

首页 / 数据库 / MySQL / 用MySQL 生成随机密码-增加大写处理

前面写过写过:http://www.linuxidc.com/Linux/2012-05/61553.htm这次增加了大写字母的处理。
  1. DELIMITER $$  
  2.   
  3. USE `t_girl`$$  
  4.   
  5. DROP FUNCTION IF EXISTS `func_rand_string`$$  
  6.   
  7. CREATE DEFINER=`root`@`localhost` FUNCTION `func_rand_string`(f_num TINYINT UNSIGNED,f_type TINYINT UNSIGNED) RETURNS VARCHAR(32) CHARSET utf8  
  8. BEGIN  
  9.       -- Translate the number to letter.   
  10.       -- No 1 stands for string only.   
  11.       -- No 2 stands for number only.   
  12.       -- No 3 stands for combination of the above.   
  13.       DECLARE i INT UNSIGNED DEFAULT 0;  
  14.       DECLARE v_result VARCHAR(255) DEFAULT "";  
  15.       WHILE i < f_num DO  
  16.         IF f_type = 1 THEN  
  17.           SET v_result = CONCAT(v_result,CHAR(65+32*(CEIL(RAND()*2)-1)+CEIL(RAND()*25)));  
  18.         ELSEIF f_type=2 THEN  
  19.           SET v_result = CONCAT(v_result,CEIL(RAND()*9));  
  20.         ELSEIF f_type=3 THEN  
  21.           IF (CEIL(RAND()*2)-1) = 1 THEN  
  22.             SET v_result = CONCAT(v_result,SUBSTRINGREPLACE(UUID(),"-",""),i+1,1));  
  23.           ELSE   
  24.             SET v_result = CONCAT(v_result,UPPERSUBSTRINGREPLACE(UUID(),"-",""),i+1,1)));  
  25.           END IF;  
  26.         END IF;  
  27.         SET i = i + 1;  
  28.       END WHILE;   
  29.       RETURN v_result;  
  30.     END$$  
  31.   
  32. DELIMITER ;  
调用方法类似。用MySQL 生成随机密码MySQL 5.5 PROXY USER 伪装用户相关资讯      MySQL数据库教程 
  • MySQL 处理非法数据  (04/09/2013 08:06:28)
  • MySQL关于timestamp和mysqldump的  (12/16/2012 13:25:41)
  • MySQL保证数据完整性  (12/16/2012 12:00:35)
  • ERROR 1130: mysql 1130连接错误的  (12/16/2012 13:29:08)
  • MySQL数据库教程:管理数据库和表(  (12/16/2012 12:47:02)
  • MySQL快速插入大批量数据存储过程  (11/05/2012 19:04:04)
本文评论 查看全部评论 (0)
表情: 姓名: 字数