91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Oracle函數獲取IDCARD中年齡

發布時間:2020-06-13 02:31:19 來源:網絡 閱讀:692 作者:xubcing 欄目:關系型數據庫

   IDCARD的第一代是15位號碼,第二代是18位號碼,

   新的18位IDCARD號碼各位的含義:1-2位省、自治區、直轄市代碼 

                                3-4位地級市、盟、自治州代碼  

                                5-6位縣、縣級市、區代碼  

                                7-14位出生年月日,比如19670401代表1967年4月1日

                                15-17位為順序號,其中17位男為單數,女為雙數  

                                18位為校驗碼,0-9和X,由公式隨機產生。

     15位IDCARD號碼各位的含義: 1-2位省、自治區、直轄市代碼;  

                               3-4位地級市、盟、自治州代碼;  

                               5-6位縣、縣級市、區代碼;   

                               7-12位出生年月日,比如670401代表1967年4月1日,這是和18位號碼的第一個區別;  

                               13-15位為順序號,其中15位男為單數,女為雙數

                               與18位***號的第二個區別:沒有最后一位的驗證碼

從IDCARD中獲取用戶年齡信息,要對IDCARD合法性進行校驗。


--判斷是否為數字,返回True,False
CREATE OR REPLACE FUNCTION DT_ISNUMBER(P_IN VARCHAR2) RETURN BOOLEAN AS
  I NUMBER ;
BEGIN
  I := TO_NUMBER(P_IN);
  RETURN TRUE;
EXCEPTION
  WHEN OTHERS THEN
    RETURN FALSE;
END;

--判斷是否為日期,返回True,False
CREATE OR REPLACE FUNCTION DT_ISDATE(P_IN VARCHAR2) RETURN BOOLEAN AS
  I DATE;
BEGIN
  I := TO_DATE(P_IN,'YYYYMMDD');
  RETURN TRUE;
EXCEPTION
  WHEN OTHERS THEN
    RETURN FALSE;
END;


--判斷是否為合法的***號
CREATE OR REPLACE FUNCTION DT_ISIDCARD(P_IDCARD VARCHAR2) RETURN BOOLEAN IS
  IDCARDLEN INTEGER;
BEGIN
  IDCARDLEN := LENGTH(P_IDCARD);
  IF (IDCARDLEN = 18 AND DT_ISNUMBER(SUBSTR(P_IDCARD, 1, IDCARDLEN - 1)) AND
     DT_ISDATE(SUBSTR(P_IDCARD, 7, 8)) ) OR
     (IDCARDLEN = 15 AND DT_ISNUMBER(SUBSTR(P_IDCARD, 1, IDCARDLEN)) AND
     DT_ISDATE('19' || SUBSTR(P_IDCARD, 7, 6)) ) THEN
    RETURN TRUE;  
  ELSE
    RETURN FALSE;
  END IF;
END DT_ISIDCARD;


--獲取***號信息的年齡并返回
CREATE OR REPLACE FUNCTION DT_GETAGE(P_IDCARD VARCHAR2) RETURN INTEGER IS
IDCARDLEN INTEGER;
IDCARDYEAR INTEGER;
BEGIN 
  IDCARDLEN :=LENGTH(P_IDCARD);  
   IF DT_ISIDCARD(P_IDCARD) AND IDCARDLEN = 18 THEN
     IDCARDYEAR := TO_NUMBER(SUBSTR(P_IDCARD,7,4));  
  END IF;
  IF DT_ISIDCARD(P_IDCARD) AND IDCARDLEN = 15 THEN  
     IDCARDYEAR := TO_NUMBER('19'||SUBSTR(P_IDCARD,7,2));
  END IF;
  RETURN  TO_NUMBER(TO_CHAR(SYSDATE,'YYYY'))-IDCARDYEAR;       
END DT_GETAGE;


 以上針對***年齡獲取常用函數做個記錄,方便日后直接使用或者對***中其他地址、性別做進一步解析使用

(PS:為啥shenfenzheng這三個字要當做敏感信息被過濾掉了呢)

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

灵石县| 常宁市| 陇南市| 喜德县| 乐山市| 惠来县| 肥乡县| 彭泽县| 商河县| 西乌| 邵东县| 若尔盖县| 体育| 淄博市| 岑巩县| 蛟河市| 三门峡市| 崇礼县| 张家港市| 信宜市| 江孜县| 大同市| 新沂市| 颍上县| 新郑市| 都昌县| 苏尼特右旗| 泊头市| 高台县| 甘孜县| 屯昌县| 东兰县| 高密市| 仙居县| 阿坝| 尼玛县| 乐业县| 颍上县| 攀枝花市| 武夷山市| 旅游|