将生产环境数据导出至测试环境或别的环境中,需将手机号、银行卡账号、姓名、身份证号及一些业务中的敏感数据进行脱敏,在mysql中可以通过以下方法根据实际应用进行处理.
DELIMITER $$
CREATE FUNCTION `f_get_rand_number`(p_size int) RETURNS int(20)
COMMENT '取参数传入长度的随机数'
BEGIN
-- select f_get_rand_number(4) ; -- 1699
DECLARE v_rand_number int(20);
DECLARE v_multiplier int;
if p_size>20 then
set p_size = 20;
end if;
set v_multiplier=RPAD('1',p_size,'0');
SELECT ROUND(RAND() * v_multiplier + v_multiplier) INTO v_rand_number;
RETURN v_rand_number;
END$$
DELIMITER ;
DELIMITER $$
CREATE FUNCTION `f_padding_str`(p_original varchar(200),p_index int ,p_padding_str varchar(1)) RETURNS varchar(200) CHARSET utf8
COMMENT '数据脱敏 将p_original从p_index位后替换成p_padding_str'
BEGIN
-- select f_padding_str('良好压顶奇才',4,'某'); -- 良好压顶某某
declare v_rtn_str varchar(200);
declare v_len int;
if p_original is null then
return '';
end if;
if char_length(p_original)>200 then
set p_original = substring(p_original,1,200);
end if;
set v_len = char_length(p_original);
set v_rtn_str = RPAD(substring(p_original,1,p_index),v_len,p_padding_str);
RETURN v_rtn_str;
END$$
DELIMITER ;
DELIMITER $$
CREATE FUNCTION `f_replace_str`(p_original varchar(200),p_index int ,p_size int,p_replace_str varchar(100)) RETURNS varchar(200) CHARSET utf8
COMMENT '数据脱敏 将p_original从p_index位后p_size长度的字符串替换成p_replace_str'
BEGIN
-- select f_replace_str('12345678',2,3,'bbb'); -- 1bbb5678
-- select f_replace_str('12345678',2,0,'bbb'); -- 1bbb
-- select f_replace_str('12345678',-2,0,'bbb');-- 123456bbb
declare v_rtn_str varchar(200);
declare v_sub_str varchar(100);
if p_original is null then
return '';
end if;
if char_length(p_original)>200 then
set p_original = substring(p_original,1,200);
end if;
-- 当p_size为0时,则将p_index后所有字符替换为p_replace_str
if p_size =0 then
set v_sub_str = substring(p_original,p_index);
else
set v_sub_str = substring(p_original,p_index,p_size);
end if;
set v_rtn_str = replace(p_original,v_sub_str,p_replace_str);
RETURN v_rtn_str;
END$$
DELIMITER ;