MYSQL统一社会信用代码校验函数

CREATE DEFINER=`tm` FUNCTION `func_check_credit_code`(v_card varchar(32)) RETURNS varchar(32) CHARSET utf8mb3
    DETERMINISTIC
BEGIN
-- 此函数用于校验明文统一社会信用代码
-- 校验通过返回 1
-- 校验不通过返回 0 
	DECLARE v_flag varchar(32) DEFAULT '';  -- 是否有效标志
	DECLARE v_sum INT DEFAULT 0;   -- 校验第一步求和
	DECLARE v_mod varchar(32) DEFAULT '';   -- 校验第二步取余
	DECLARE i_flag varchar(32) DEFAULT '';  -- 校验第三步计算校验位
	DECLARE v_cstr varchar(200) DEFAULT '';  
	DECLARE v_wstr varchar(200) DEFAULT '';  -- 加权因子字符串
	
-- 每一位对应的数字
	SET v_cstr = '0123456789ABCDEFGHJKLMNPQRTUWXY';
-- 对应数字的加权因子
	SET v_wstr = '1, 3, 9, 27, 19, 26, 16, 17, 20, 29, 25, 13, 8, 24, 10, 30, 28';
	
-- 长度不等于18为空
	IF LENGTH(v_card) <> 18 THEN
	RETURN 0;
	END IF;
	
-- 判断第一位登记管理部门代码
	IF SUBSTRING(v_card,1,1) NOT IN (1,2,3,4,5,6,7,8,9,'A','N','Y') THEN
	RETURN 0;
	END IF;
	
-- 判断第二位机构类别代码
-- 判断机构编制
	IF SUBSTRING(v_card,1,1) = 1 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,2,3,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断外交
	IF SUBSTRING(v_card,1,1) = 2 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断司法行政
	IF SUBSTRING(v_card,1,1) = 3 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,2,3,4,5,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断文化	
	IF SUBSTRING(v_card,1,1) = 4 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断民政
	IF SUBSTRING(v_card,1,1) = 5 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,2,3,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断旅游	
	IF SUBSTRING(v_card,1,1) = 6 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,2,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断宗教
	IF SUBSTRING(v_card,1,1) = 7 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,2,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断工会	
	IF SUBSTRING(v_card,1,1) = 8 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断工商	
	IF SUBSTRING(v_card,1,1) = 9 THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,2,3) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断中央军委改革和编制办公室
	IF SUBSTRING(v_card,1,1) = 'A' THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断农业
	IF SUBSTRING(v_card,1,1) = 'N' THEN
		IF SUBSTRING(v_card,2,1) NOT IN (1,2,3,9) THEN
		RETURN 0;
		END IF;
	END IF;
-- 判断其他
	IF SUBSTRING(v_card,1,1) = 'Y' THEN
		IF SUBSTRING(v_card,2,1) <> 1 THEN
		RETURN 0;
		END IF;
	END IF;

-- 判断区划代码前两位
	IF SUBSTRING(v_card,3,2) NOT IN (11,12,13,14,15,21,22,23,31,32,33,34,35,36,37,41,42,43,44,45,46,50,51,52,53,54,61,62,63,64,65,71,81,83) THEN
	RETURN 0;
	END IF;
	
-- 求和
SET v_sum =  (INSTR(v_cstr, SUBSTR(v_card, 1, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',1)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 2, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',2)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 3, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',3)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 4, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',4)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 5, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',5)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 6, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',6)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 7, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',7)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 8, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',8)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 9, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',9)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 10, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',10)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 11, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',11)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 12, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',12)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 13, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',13)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 14, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',14)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 15, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',15)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 16, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',16)),',',1))+
(INSTR(v_cstr, SUBSTR(v_card, 17, 1)) - 1)*REVERSE(SUBSTRING_INDEX(REVERSE(SUBSTRING_INDEX(v_wstr,',',17)),',',1));
	
-- 取余得到加权因子
SET v_mod = 31 - v_sum%31;
IF v_mod = 31 THEN 
	SET v_mod = 0 ;
END IF;

-- 判断校验位
SET i_flag = SUBSTR(v_cstr,v_mod+1,1);
IF i_flag = SUBSTRING(v_card,18,1) THEN
RETURN 1;
		ELSE
		RETURN 0;
	END IF;

END


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL 中没有直接的“爆炸函数”(explode function),但可以使用内置函数 SUBSTRING_INDEX 实现类似的功能。SUBSTRING_INDEX 函数的语法如下: ``` SUBSTRING_INDEX(str,delim,count) ``` 其中,str 是要处理的字符串,delim 是分隔符,count 是要返回的子字符串的个数。例如,如果要将字符串 "one,two,three" 按照逗号分隔,得到第二个子字符串 "two",可以使用以下语句: ``` SELECT SUBSTRING_INDEX('one,two,three', ',', 2); ``` 输出结果为:`one,two`。 如果要实现类似于 PHP 中的 explode 函数,可以使用 SUBSTRING_INDEX 函数结合 MySQL 的 GROUP_CONCAT 函数和临时表。例如,如果要将字符串 "one,two,three" 按照逗号分隔成多行,可以使用以下语句: ``` SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('one,two,three', ',', n), ',', -1) AS value FROM (SELECT 1 n UNION ALL SELECT 2 UNION ALL SELECT 3) numbers WHERE n <= LENGTH('one,two,three') - LENGTH(REPLACE('one,two,three', ',', '')) + 1; ``` 输出结果为: ``` value ----- one two three ``` 其中,临时表 numbers 包含了要分隔的字符串的子字符串的个数,通过 WHERE 子句限制了子字符串的个数不超过字符串中逗号的个数加一。内部的 SUBSTRING_INDEX 函数用于提取子字符串,最终使用 GROUP_CONCAT 函数将结果拼接成多行。 ### 回答2: MySQL并没有提供"爆炸函数"这个概念。或许你是指MySQL中的EXPLODE()函数,但实际上MySQL并没有内置这个函数。 "爆炸函数"通常是指在其他编程语言中用于将字符串分割成数组的函数,而MySQL中没有单独的函数可以直接实现该功能。但是,我们可以使用其他MySQL内置的函数来达到类似的效果。 例如,可以使用SUBSTRING_INDEX()函数和GROUP_CONCAT()函数来实现类似于explode()函数的分隔字符串操作。 具体方法如下: 1. 使用SUBSTRING_INDEX()函数将字符串分割成多个部分:例如,SUBSTRING_INDEX('a,b,c', ',', 1)将返回'a',SUBSTRING_INDEX('a,b,c', ',', -1)将返回'c'。 2. 使用GROUP_CONCAT()函数将分割后的多个部分重新合并成一个字符串:例如,SELECT GROUP_CONCAT(SUBSTRING_INDEX('a,b,c', ',', 1))将返回'a,b,c'。 通过将这两个函数结合使用,可以模拟实现类似于explode()函数的功能。 当然,也可以通过编写自定义函数来实现类似的功能。自定义函数可以使用循环和字符串操作来实现对字符串的分割和拼接。这样,就能够实现"爆炸函数"的功能。 总而言之,MySQL没有内置的"爆炸函数",但我们可以使用其他的内置函数或编写自定义函数来实现类似的功能。 ### 回答3: MySQL中并没有"爆炸函数"这个术语。也许你指的是MySQL数据库中的某个函数或语句,可能会在某些情况下导致意外的结果或运行错误的情况。 在MySQL中,有一些函数和语句在使用时需要谨慎,因为它们可能会导致一些可能不符合预期的结果。例如,使用不正确的条件语句可能导致查询结果不正确,或者使用不合理的参数可能导致函数无法正常工作。 此外,可能存在SQL注入问题,这是一种常见的数据库攻击方式。如果没有正确的对用户输入进行验证和过滤,恶意用户可能会通过构造恶意的输入来执行非法的SQL语句,导致数据泄露、破坏或越权访问。 为了避免这些问题,我们应该始终遵循数据库最佳实践。确保在编写SQL语句时使用合适的条件语句和参数,以及正确地对用户输入进行验证和过滤。此外,定期更新和维护MySQL软件,以确保安全性和功能的稳定性。 总结来说,尽管MySQL数据库本身没有"爆炸函数"这个概念,但是在使用MySQL时,我们需要注意一些可能导致预期之外结果的函数和语句,同时需要采取措施来防御SQL注入等安全问题,以确保数据库的正常运行和数据的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值