用MySQL 生成随机密码-增加大写处理


前面写过写过:

这次增加了大写字母的处理。

  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,SUBSTRING(REPLACE(UUID(),'-',''),i+1,1));  
  23.           ELSE   
  24.             SET v_result = CONCAT(v_result,UPPER(SUBSTRING(REPLACE(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 ;  

调用方法类似。

相关内容