日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql数据自定义随机_Mysql 自定义随机字符串

發(fā)布時間:2025/3/11 数据库 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql数据自定义随机_Mysql 自定义随机字符串 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

前幾天在開發(fā)一個系統(tǒng),需要用到隨機字符串,但是mysql的庫函數(shù)有沒有直接提供,就簡單的利用現(xiàn)有的函數(shù)東拼西湊出隨機字符串來.下面簡單的說下實現(xiàn)當時.

1.簡單粗暴.

select ..., substring(MD5(RAND()),floor(RAND()*26)+1,6) as rand_str .....

上訴示例產生的是:6位長度的隨機字符串.

函數(shù)解釋:

rand() :產生 0-1之間的小數(shù),簡稱種子.rand()*25 產生的數(shù) 在 0- 25 之間,不包括25

floor(val): 生成最近接val的最大整數(shù)

md5() :對字符串進行Md5加密(單向),生成的字符串長度是32位。

substring(str,pos,len):截取字符串,第一個參數(shù):待截取的字符串,第二個參數(shù):開始的位置(這里有些不同,下標開始位置為1,可以試試下),第三個參數(shù):截取的長度.

2.將方式1進行包裝一下:自定義函數(shù)

drop function if exists rand_str;

#第一句: 如果存在重名函數(shù),就將其刪除

create function rand_str(strlen smallint) returns varchar(255)

#第二句: 定義一個函數(shù),名稱'rand_str' ,參數(shù)名 strlen 參數(shù)類型 smallint , 返回值類型 varchar(255) ,特別 注意下 這里的 是returns 下面的是 return

#BEGIN

#相當于左大括號 '{'

DECLARE result_str VARCHAR(255) DEFAULT '';

#聲明返回值對象,類型 ,長度 ,默認值

SET result_str =SUBSTRING(MD5(RAND()),32-strlen,strlen);

#設置返回值對象的值 方式1中簡單粗暴的函數(shù)

RETURN result_str;

#返回 結果對象 這里的是 return

END

# 結束標識 相當于 '}'

3.自定義函數(shù)直接上代碼

每一句的實現(xiàn)就不解釋了,可以參加方式2中的代碼解釋看一下

DROP FUNCTION IF EXISTS rand_str;

create FUNCTION rand_str(strlen SMALLINT ) RETURNS VARCHAR(255)

BEGIN

DECLARE randStr VARCHAR(255) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890';

DECLARE i SMALLINT DEFAULT 0;

DECLARE resultStr VARCHAR(255) DEFAULT '';

WHILE i

SET resultStr=CONCAT(SUBSTR(randStr,FLOOR(RAND()*LENGTH(randStr))+1,1),resultStr);

SET i=i+1;

END WHILE;

RETURN resultStr;

END

總結

以上是生活随笔為你收集整理的mysql数据自定义随机_Mysql 自定义随机字符串的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。