Greenplum数据库身份证查验函数

以下为 Greenplum 6.x 专用 的身份证校验函数,完整保留原始逻辑,无任何删减或优化,可直接复制使用:

sql 复制代码
CREATE OR REPLACE FUNCTION CHECK_ID_CARD("sfzh" varchar)
  RETURNS varchar AS $body$  
DECLARE
    RESULTS varchar(30);
BEGIN
	RESULTS := CASE
	WHEN sfzh IS NULL THEN
		'身份证号不能为空'
	WHEN LENGTH(sfzh) <> 18 THEN
		'身份证号码必须为18位'
	WHEN (substring(sfzh,1,17) ~ '[^0-9]' ) = 't' THEN
	  '身份证号码前17位格式不正确'
	WHEN substring(sfzh,7,4) NOT BETWEEN '1900' AND to_char(now(),'YYYY') THEN
		'身份证年份错误'
	WHEN substring(sfzh,11,2) NOT BETWEEN '01' AND '12' THEN 
		'身份证月份错误'
	WHEN substring(sfzh,13,2) NOT BETWEEN '01' AND to_char((date_trunc('month',to_date
	(CONCAT(substring(sfzh,7,4),'-',substring(sfzh,11,2),'-01'),'YYYY-MM-DD')) + interval '1 month' - interval '1 day'),'dd') THEN 
		'身份证日期错误'
	WHEN 
		mod(( 
            to_number(substring(sfzh,1,1),'9')*7+ 
            to_number(substring(sfzh,2,1),'9')*9+ 
            to_number(substring(sfzh,3,1),'9')*10+ 
            to_number(substring(sfzh,4,1),'9')*5+ 
            to_number(substring(sfzh,5,1),'9')*8+ 
            to_number(substring(sfzh,6,1),'9')*4+ 
            to_number(substring(sfzh,7,1),'9')*2+ 
            to_number(substring(sfzh,8,1),'9')*1+ 
            to_number(substring(sfzh,9,1),'9')*6+ 
            to_number(substring(sfzh,10,1),'9')*3+ 
            to_number(substring(sfzh,11,1),'9')*7+ 
            to_number(substring(sfzh,12,1),'9')*9+ 
            to_number(substring(sfzh,13,1),'9')*10+ 
            to_number(substring(sfzh,14,1),'9')*5+ 
            to_number(substring(sfzh,15,1),'9')*8+ 
            to_number(substring(sfzh,16,1),'9')*4+ 
            to_number(substring(sfzh,17,1),'9')*2 
          ),11) 
			<> to_number(
          ( 
          case
            when substring(sfzh,18,1)='1' then '0'
            when substring(sfzh,18,1)='0' then '1'
            when substring(sfzh,18,1) in ('X','x') then '2'
            when substring(sfzh,18,1)='9' then '3'
            when substring(sfzh,18,1)='8' then '4'
            when substring(sfzh,18,1)='7' then '5'
            when substring(sfzh,18,1)='6' then '6'
            when substring(sfzh,18,1)='5' then '7'
            when substring(sfzh,18,1)='4' then '8'
            when substring(sfzh,18,1)='3' then '9'
            when substring(sfzh,18,1)='2' then '10'
          end
          ),'99')
	THEN
		'身份证验证错误'
	ELSE
		'ok'
	END;
	Return(RESULTS);
END
$body$ LANGUAGE plpgsql;

核心逻辑说明

  1. 长度与格式

    LENGTH(sfzh) = 前17位全数字 + 第18位合法(数字/X/x)

  2. 日期合法性

    -- 自动校验当月最大天数(含闰年)
    to_char(date_trunc('month', to_date(...)) + interval '1 month' - interval '1 day', 'dd')

  3. 校验码算法 (GB 11643-1999)

    • 前17位按权重 [7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2] 加权求和
    • 求和后 mod 11
    • 根据余数映射校验码(0→1, 1→0, 2→X, 3→9, ..., 10→2

使用示例

sql 复制代码
-- 检查异常身份证
SELECT 
  sfzh,
  CHECK_ID_CARD(sfzh) AS check_result
FROM user_info

-- 输出示例:
-- 110101199002301234 | 身份证日期错误
-- 11010119900101123X | 身份证验证错误
-- 110101199001011234 | ok
相关推荐
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest4 天前
数据库SQL学习
数据库·sql
jnrjian4 天前
ORA-01017 查找机器名 用户名 以及library cache lock 参数含义
数据库·oracle