Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

DDMMYY को DDMMYYYY में कनवर्ट करना यदि जन्म 00-49

दो अंकों वाले वर्ष की व्याख्या और इसकी निहित शताब्दी इसके मूल्य और पिन दोनों पर आधारित प्रतीत होती है। उस ओवरलैप की सीमाएं, लेकिन फिर पूरा वर्ष प्रतिबंधित है; तो ऐसा लगता है कि आप एक केस एक्सप्रेशन का उपयोग कर सकते हैं जो दोनों की जांच करता है:

-- CTE for dummy data
with t42 (ssn) as (
  select '12104900000' from dual
  union all select '12105099999' from dual
  union all select '01010000001' from dual
  union all select '02029949902' from dual
  union all select '03035450003' from dual
  union all select '04049974904' from dual
  union all select '05050050005' from dual
  union all select '06063999906' from dual
  union all select '07074090007' from dual
  union all select '08089999908' from dual
)
select ssn, to_date(substr(ssn, 1, 4)
  || case
      when to_number(substr(ssn, 7, 3)) between 0 and 499
        and to_number(substr(ssn, 5, 2)) between 0 and 99 then '19'
      when to_number(substr(ssn, 7, 3)) between 500 and 749
        and to_number(substr(ssn, 5, 2)) between 54 and 99 then '18'
      when to_number(substr(ssn, 7, 3)) between 500 and 999
        and to_number(substr(ssn, 5, 2)) between 0 and 39 then '20'
      when to_number(substr(ssn, 7, 3)) between 900 and 999
        and to_number(substr(ssn, 5, 2)) between 40 and 99 then '19'
    end
  || substr(ssn, 5, 2), 'DDMMYYYY') as dob
from t42;

जो उस डेटा के लिए, आपके दो उदाहरणों और शामिल श्रेणियों के आधार पर देता है:

SSN         DOB       
----------- ----------
12104900000 1949-10-12
12105099999 1950-10-12
01010000001 1900-01-01
02029949902 1999-02-02
03035450003 1854-03-03
04049974904 1899-04-04
05050050005 2000-05-05
06063999906 2039-06-06
07074090007 1940-07-07
08089999908 1999-08-08

मामला पिन के आधार पर दो अंकों की सदी का मान चुनता है और फिर - क्योंकि वे ओवरलैप होते हैं - दो अंकों की वर्ष सीमा।

यदि डेटा डिज़ाइन बदलता है, तो दो अंकों वाले वर्ष के आधार पर ओवरलैप अब अद्वितीय नहीं हैं, तो आपके पास और समस्याएं हैं। यह देखना दिलचस्प होगा कि 2040 तक पहुंचने पर क्या होता है...

और अगर आपके पास एक SSN था जो आपके द्वारा दिखाई गई श्रेणियों से मेल नहीं खाता, तो 12105050000 कहें (पिन 500 के साथ, लेकिन दो अंकों वाला वर्ष 00-39 या 54-99 में से किसी भी श्रेणी में नहीं है) तो केस एक्सप्रेशन शून्य हो जाएगा और दो अंकों वाले वर्ष को 0050 के रूप में व्याख्यायित किया जाएगा। आप इसे बदलकर त्रुटि कर सकते हैं प्रारूप मॉडल - निर्भर करता है कि क्या यह हो सकता है और यदि ऐसा होता है तो आप इसे कैसे संभालना चाहते हैं।

आप शायद इसे वैसे भी समझ सकते हैं, लेकिन टिप्पणियों में उल्लिखित दिन +40 परिदृश्य को संभालने के लिए, आप दिन की संख्या को समायोजित करने के लिए किसी अन्य केस एक्सप्रेशन का उपयोग कर सकते हैं:

select ssn, to_date(
    case
      when substr(ssn, 1, 2) > 31 then to_char(to_number(substr(ssn, 1, 2)) - 40, 'FM99')
      else substr(ssn, 1, 2)
    end
  || substr(ssn, 3, 2)
  || case
      when to_number(substr(ssn, 7, 3)) between 0 and 499
...



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. औसत भारित मूल्य खोजने की क्वेरी

  2. सी ++ और जावा के बीच ओरेकल लेनदेन का प्रचार

  3. आईओटी का उपयोग कर ओरेकल में क्लस्टर्ड-इंडेक्स बनाना? भ्रम

  4. Php Oracle कनेक्शन:oci_connect ():ORA-24315:अवैध विशेषता प्रकार त्रुटि

  5. OBIEE 11G राइटबैक XML डालें