CREATE OR REPLACE FUNCTION FUN_CHECKIDCARD(PI_AAC002 VARCHAR2)
  RETURN VARCHAR2 IS

/******************************************************************************
  *  程序名:身份证合法性校验FUN_CHECKIDCARD
  * 程序功能:对人员的身份证合法性进行校验
  *   输入:身份证号码
  *   输出:返回值: 0 合法;
  * 版本日期:2015-01-16
  * 执行类型:用户手工执行
  * 修改过程:
  ******************************************************************************/
  TYPE UDT_CHECK IS TABLE OF NUMBER;
  UDO_CHECK UDT_CHECK := UDT_CHECK(7,
                                   9,
                                   10,
                                   5,
                                   8,
                                   4,
                                   2,
                                   1,
                                   6,
                                   3,
                                   7,
                                   9,
                                   10,
                                   5,
                                   8,
                                   4,
                                   2); --初始化校验位

L_RESULT NUMBER := 0;
  L_STR    NUMBER;
BEGIN
  --15位身份证
  IF LENGTHB(PI_AAC002) = 15 THEN
    --身份证号不对
    IF FUN_ISDATE('19' || SUBSTR(PI_AAC002, 7, 6)) = 0 THEN
      RETURN 1;
    END IF;
    IF FUN_ISNUMBER(PI_AAC002) = 0 THEN
      RETURN 2;
    END IF;
    --18位身份证
  ELSIF LENGTHB(PI_AAC002) = 18 THEN
    IF FUN_ISDATE(SUBSTR(PI_AAC002, 7, 8)) = 0 THEN
      RETURN 3;
    END IF;
    IF FUN_ISNUMBER(SUBSTR(PI_AAC002, 1, 17)) = 0 THEN
      RETURN 4;
    END IF;
    IF FUN_ISNUMBER(SUBSTR(PI_AAC002, 18, 1)) = 0 OR
       SUBSTR(PI_AAC002, 18, 1) <> 'x' OR SUBSTR(PI_AAC002, 18, 1) <> 'X' THEN
      RETURN 5;
    END IF;
  
    --验证校验位开始
    FOR I IN 1 .. LENGTH(PI_AAC002) - 1 LOOP
      L_STR    := SUBSTR(PI_AAC002, I, 1);
      L_RESULT := L_RESULT + L_STR * UDO_CHECK(I);
    END LOOP;
    L_STR := MOD(L_RESULT, 11);
    SELECT DECODE(L_STR,
                  0,
                  1,
                  1,
                  0,
                  2,
                  'X',
                  3,
                  9,
                  4,
                  8,
                  5,
                  7,
                  6,
                  6,
                  7,
                  5,
                  8,
                  4,
                  9,
                  3,
                  10,
                  2)
      INTO L_RESULT
      FROM DUAL;
    IF SUBSTR(PI_AAC002, LENGTH(PI_AAC002), 1) <> L_RESULT THEN
      RETURN 7;
    ELSE
      RETURN 0;
    END IF;
  ELSE
    RETURN 6;
  END IF;
  RETURN 0;
END FUN_CHECKIDCARD;

其中FUN_ISDATE 与FUN_ISNUMBER分别是判断是否是时间或着数据的函数:

CREATE OR REPLACE FUNCTION FUN_ISDATE(PI_PARAMETER VARCHAR2)
  RETURN VARCHAR2 IS
  L_VAL DATE;
BEGIN
  L_VAL := TO_DATE(NVL(PI_PARAMETER, 'a'), 'yyyy-mm-dd hh24:mi:ss');
  RETURN 1;
EXCEPTION
  WHEN OTHERS THEN
    RETURN 0;
END FUN_ISDATE;

CREATE OR REPLACE FUNCTION FUN_ISNUMBER(PI_PARAMETER VARCHAR2)
  RETURN VARCHAR2 IS
  L_VAL NUMBER;
BEGIN
  L_VAL := TO_NUMBER(NVL(PI_PARAMETER, 'a'));
  RETURN 1;
EXCEPTION
  WHEN OTHERS THEN
    RETURN 0;
END FUN_ISNUMBER;

PLSQL存储过程校验身份证的更多相关文章

  1. JS校验身份证号的合法性

    前端表单中有身份证号的校验,下边是用JS来校验身份证号的合法性. 中国居民身份证号码编码规则 第一.二位表示省(自治区.直辖市.特别行政区). 第三.四位表示市(地级市.自治州.盟及国家直辖市所属市辖 ...

  2. oracel存储过程编写 以及plsql存储过程的debug

    1.语法: create or replace procedure messagebackup_createTable       //此处存储过程名称不能超过30个字符 as  tableName ...

  3. plsql 存储过程 测试

      plsql 存储过程 测试 CreationTime--2018年8月14日09点54分 Author:Marydon 1.找到要运行的存储过程-->选中-->右键-->测试 2 ...

  4. js 校验身份证号

    根据地区编码.身份证格式.18位身份证需要验证最后一位校验位 //校验身份证 function IdentityCodeValid(code) { var city = { 11: "北京& ...

  5. Oracle/PLSQL存储过程详解

    原文链接:https://blog.csdn.net/zezezuiaiya/article/details/79557621 Oracle/PLSQL存储过程详解 2018-03-14 17:31: ...

  6. Java中校验身份证号合法性(真伪),获取出生日期、年龄、性别、籍贯

    开发过程中有用的身份证号的业务场景,那么校验身份证的合法性就很重要了,另外还有通过身份证获取出生日期.年龄.性别.籍贯等信息, 下面是本人在开发中用到的关于校验身份证真伪的工具类,可以直接拿来使用,非 ...

  7. js校验身份证

    1 <%@page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8" %> &l ...

  8. Js正则校验身份证号码

    原文链接:http://gongwen.sinaapp.com/article-126-cmd 这个其实不难,在网上多找一下总会有意外收获的.但是工欲善其事,必先利其器.我们需要了解一下身份证号的规则 ...

  9. java校验身份证号码

    /** * 18位身份证校验,粗略的校验 * @author lyl * @param idCard * @return */ public static boolean is18ByteIdCard ...

随机推荐

  1. 用paint 计算字符串的像素宽度

    方法1: //直接返回参数字符串所占用的像素宽度 Paint paint = new Paint(); width = paint.measureText(str); 有一些view可以直接得到pai ...

  2. new int[]和new int()的区别

    1. new int[] 是创建一个int型数组,数组大小是在[]中指定,例如:int * p = new int[10]; //p执行一个长度为10的int数组.2. new int()是创建一个i ...

  3. Ubuntu 64位系统安装StarUML之最佳实践

    preview 相信很多使用Ubuntu的哥们在安装StarUML或者其他软件时都会遇到要求libgcrypt11的依赖.而遗憾的时,这个东西很多人根本找不到. 我将它分享到百度网盘,mark. 一. ...

  4. table share

    每个表的表结构会放到table_def_cache中,一个table share对应一个实例 table share 又会实例化为一个对象, 每个进程,每个实例化的对象,

  5. jquery图表插件morris.js参数详解和highcharts图表插件

    一.morris.js 优点:轻巧.简单好用 缺点:没highcharts功能多,常用的足以 网址:http://morrisjs.github.io/morris.js/ 核心代码 1.head调用 ...

  6. 基于ffmpeg的简单音视频编解码的例子

    近日需要做一个视频转码服务器,对我这样一个在该领域的新手来说却是够我折腾一番,在别人的建议下开始研究开源ffmpeg项目,下面是在代码中看到的一 段例子代码,对我的学习非常有帮助.该例子代码包含音频的 ...

  7. android中ViewHolder通用简洁写法

    public class ViewHolder {     // I added a generic return type to reduce the casting noise in client ...

  8. MyBatis 如何接收参数

    MyBatis的mapper接口不需要自己实现,框架会自动帮我们实现,到时候直接调用就可以了.定义的mapper接口中的方法可以有多个参数吗?答案是肯定.在Ibatis时代是自己通过代码实现如何调用x ...

  9. OracleHelper(for produce)

    OracleHelper中,有一个用存储过程实现的Insert方法. 然后我把执行存储过程的方法 封装成了可以执行任何存储过程,参数是 存储过程名称 以及存错过程中的传入.传出参数 using Ora ...

  10. 擦亮自己的眼睛去看SQLServer之简单Insert(转)

    摘要:本来是打算先写SQLServer历史的,不过感觉写那部分内容比较难还需要多查些资料.于是调整了下顺序写下简单的Insert语句. 不过感觉写那部分内容比较难还需要多查些资料.于是调整了下顺序写下 ...