PL / SQL - डेटा प्रकार

इस अध्याय में, हम PL / SQL में डेटा प्रकारों पर चर्चा करेंगे। पीएल / एसक्यूएल चर, स्थिरांक और पैरामीटर में एक वैध डेटा प्रकार होना चाहिए, जो एक भंडारण प्रारूप, बाधाओं और मान्य मानों को निर्दिष्ट करता है। हम पर ध्यान केंद्रित करेंगेSCALAR और यह LOBइस अध्याय में डेटा प्रकार। अन्य दो डेटा प्रकार अन्य अध्यायों में शामिल किए जाएंगे।

S.No वर्ग विवरण
1

Scalar

कोई आंतरिक घटकों के साथ एकल मान, जैसे कि ए NUMBER, DATE, या BOOLEAN

2

Large Object (LOB)

बड़े ऑब्जेक्ट्स के लिए पॉइंटर्स जो अन्य डेटा आइटम्स, जैसे टेक्स्ट, ग्राफिक इमेज, वीडियो क्लिप और साउंड वेवफॉर्म से अलग-अलग स्टोर किए जाते हैं।

3

Composite

डेटा आइटम जिसमें आंतरिक घटक होते हैं जिन्हें व्यक्तिगत रूप से एक्सेस किया जा सकता है। उदाहरण के लिए, संग्रह और रिकॉर्ड।

4

Reference

अन्य डेटा आइटम के लिए संकेत।

PL / SQL स्केलर डेटा प्रकार और उपप्रकार

PL / SQL स्केलर डेटा प्रकार और उपप्रकार निम्नलिखित श्रेणियों के अंतर्गत आते हैं -

S.No दिनांक प्रकार और विवरण
1

Numeric

संख्यात्मक मान जिस पर अंकगणितीय ऑपरेशन किए जाते हैं।

2

Character

अक्षरांकीय मान जो एकल वर्णों या वर्णों के तार का प्रतिनिधित्व करते हैं।

3

Boolean

तार्किक मूल्य, जिस पर तार्किक कार्य किए जाते हैं।

4

Datetime

दिनांक और समय।

PL / SQL डेटा प्रकार के उपप्रकार प्रदान करता है। उदाहरण के लिए, डेटा प्रकार NUMBER में INTEGER नामक एक उपप्रकार है। आप पीएल / एसक्यूएल कोड को किसी अन्य प्रोग्राम, जैसे जावा प्रोग्राम में एम्बेड करते समय डेटा प्रकार को अन्य प्रोग्राम में डेटा प्रकार के साथ संगत बनाने के लिए अपने पीएल / एसक्यूएल प्रोग्राम में उपप्रकारों का उपयोग कर सकते हैं।

PL / SQL संख्यात्मक डेटा प्रकार और उपप्रकार

निम्न तालिका में पीएल / एसक्यूएल पूर्व-परिभाषित संख्यात्मक डेटा प्रकारों और उनके उप-प्रकारों की सूची दी गई है -

S.No डेटा प्रकार और विवरण
1

PLS_INTEGER

2,147,483,647 के माध्यम से सीमा -2,147,483,648 में पूर्णांक, 32 बिट में दर्शाया गया

2

BINARY_INTEGER

2,147,483,647 के माध्यम से सीमा -2,147,483,648 में पूर्णांक, 32 बिट में दर्शाया गया

3

BINARY_FLOAT

एकल-सटीक IEEE 754-फ़्लोटिंग फ़्लोटिंग-पॉइंट संख्या

4

BINARY_DOUBLE

डबल-सटीक IEEE 754-फ़्लोटिंग फ़्लोटिंग पॉइंट संख्या

5

NUMBER(prec, scale)

1E-130 से (लेकिन शामिल नहीं) 1.0E126 तक की सीमा में पूर्ण मूल्य के साथ फिक्स्ड-पॉइंट या फ्लोटिंग-पॉइंट नंबर। एक NUMBER वैरिएबल 0 का प्रतिनिधित्व कर सकता है

6

DEC(prec, scale)

38 दशमलव अंकों की अधिकतम परिशुद्धता के साथ ANSI विशिष्ट निश्चित-बिंदु प्रकार

7

DECIMAL(prec, scale)

38 दशमलव अंकों की अधिकतम परिशुद्धता के साथ आईबीएम विशिष्ट निश्चित-बिंदु प्रकार

8

NUMERIC(pre, secale)

38 दशमलव अंकों की अधिकतम सटीकता के साथ फ्लोटिंग प्रकार

9

DOUBLE PRECISION

ANSI विशिष्ट फ़्लोटिंग-पॉइंट प्रकार जिसमें अधिकतम बाइनरी 126 बाइनरी अंक (लगभग 38 दशमलव अंक) हैं

10

FLOAT

ANSI और IBM विशिष्ट फ़्लोटिंग-पॉइंट प्रकार जिसमें अधिकतम बाइनरी 126 बाइनरी अंक (लगभग 38 दशमलव अंक) हैं

1 1

INT

एएनएसआई विशिष्ट पूर्णांक प्रकार 38 दशमलव अंकों की अधिकतम परिशुद्धता के साथ

12

INTEGER

ANSI और IBM विशिष्ट पूर्णांक प्रकार 38 दशमलव अंकों की अधिकतम परिशुद्धता के साथ

13

SMALLINT

ANSI और IBM विशिष्ट पूर्णांक प्रकार 38 दशमलव अंकों की अधिकतम परिशुद्धता के साथ

14

REAL

63 बाइनरी अंकों की अधिकतम सटीकता (लगभग 18 दशमलव अंक) के साथ फ्लोटिंग-पॉइंट प्रकार

निम्नलिखित एक वैध घोषणा है -

DECLARE 
   num1 INTEGER; 
   num2 REAL; 
   num3 DOUBLE PRECISION; 
BEGIN 
   null; 
END; 
/

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

PL/SQL procedure successfully completed

पीएल / एसक्यूएल चरित्र डेटा प्रकार और उपप्रकार

निम्नलिखित पीएल / एसक्यूएल पूर्व-परिभाषित चरित्र डेटा प्रकारों और उनके उप-प्रकारों का विवरण है -

S.No डेटा प्रकार और विवरण
1

CHAR

32,767 बाइट्स के अधिकतम आकार के साथ फिक्स्ड-लेंथ कैरेक्टर स्ट्रिंग

2

VARCHAR2

32,767 बाइट्स के अधिकतम आकार के साथ चर-लंबाई चरित्र स्ट्रिंग

3

RAW

परिवर्तनीय-लंबाई बाइनरी या बाइट स्ट्रिंग 32,767 बाइट्स के अधिकतम आकार के साथ, पीएल / एसक्यूएल द्वारा व्याख्या नहीं की गई

4

NCHAR

32,767 बाइट्स के अधिकतम आकार के साथ निश्चित लंबाई वाला राष्ट्रीय चरित्र स्ट्रिंग

5

NVARCHAR2

32,767 बाइट्स के अधिकतम आकार के साथ चर-लंबाई वाला राष्ट्रीय चरित्र स्ट्रिंग

6

LONG

32,760 बाइट्स के अधिकतम आकार के साथ चर-लंबाई चरित्र स्ट्रिंग

7

LONG RAW

32,760 बाइट्स के अधिकतम आकार के साथ परिवर्तनीय-लंबाई बाइनरी या बाइट स्ट्रिंग, पीएल / एसक्यूएल द्वारा व्याख्या नहीं की गई

8

ROWID

भौतिक पंक्ति पहचानकर्ता, एक साधारण तालिका में एक पंक्ति का पता

9

UROWID

यूनिवर्सल पंक्ति पहचानकर्ता (भौतिक, तार्किक या विदेशी पंक्ति पहचानकर्ता)

PL / SQL बुलियन डेटा प्रकार

BOOLEANडेटा प्रकार तार्किक मानों को संग्रहीत करता है जो तार्किक संचालन में उपयोग किए जाते हैं। तार्किक मूल्य बूलियन मूल्य हैंTRUE तथा FALSE और मूल्य NULL

हालाँकि, SQL में BOOLEAN के बराबर कोई डेटा प्रकार नहीं है। इसलिए, बुलियन मूल्यों का उपयोग नहीं किया जा सकता है -

  • एसक्यूएल बयान
  • अंतर्निहित SQL फ़ंक्शंस (जैसे कि TO_CHAR)
  • पीएल / एसक्यूएल फ़ंक्शन एसक्यूएल बयानों से आहूत

पीएल / एसक्यूएल डेटाइम और इंटरवल प्रकार

DATEडेटेटाइप का उपयोग निश्चित लंबाई के डेटासेट को संग्रहीत करने के लिए किया जाता है, जिसमें आधी रात के बाद से सेकंड में दिन का समय शामिल होता है। मान्य तिथियां 1 जनवरी, 4712 ईसा पूर्व से 31 दिसंबर, 9999 ईस्वी तक की हैं।

डिफ़ॉल्ट दिनांक स्वरूप Oracle प्रारंभकरण पैरामीटर NLS_DATE_FORMAT द्वारा सेट किया गया है। उदाहरण के लिए, डिफ़ॉल्ट 'DD-MON-YY' हो सकता है, जिसमें महीने के दिन के लिए दो अंकों की संख्या, महीने के नाम का एक संक्षिप्त नाम और वर्ष के अंतिम दो अंक शामिल होते हैं। उदाहरण के लिए, 01-OCT-12।

प्रत्येक DATE में शताब्दी, वर्ष, महीना, दिन, घंटा, मिनट और दूसरा शामिल है। निम्न तालिका प्रत्येक क्षेत्र के लिए मान्य मान दिखाती है -

कार्यक्षेत्र नाम मान्य डेटाटाइम मान वैध अंतराल मान
साल -4712 से 9999 (वर्ष 0 को छोड़कर) कोई भी नॉनजरो पूर्णांक
महीना 01 से 12 0 से 11
दिन 01 से 31 (स्थानीय लोगों के लिए कैलेंडर के नियमों के अनुसार MONTH और YEAR के मूल्यों तक सीमित) कोई भी नॉनजरो पूर्णांक
इस घंटे 00 से 23 तक 0 से 23
मिनट 00 से 59 0 से 59
दूसरा 00 से 59.9 (एन), जहां 9 (एन) समय आंशिक सेकंड की सटीकता है 0 से 59.9 (एन), जहां 9 (एन) अंतराल के आंशिक सेकंड की सटीकता है
TIMEZONE_HOUR -12 से 14 (दिन की बचत समय परिवर्तन को समायोजित करता है) लागू नहीं
TIMEZONE_MINUTE 00 से 59 लागू नहीं
TIMEZONE_REGION गतिशील प्रदर्शन दृश्य V $ TIMEZONE_NAMES में मिला लागू नहीं
TIMEZONE_ABBR गतिशील प्रदर्शन दृश्य V $ TIMEZONE_NAMES में मिला लागू नहीं

PL / SQL बड़े ऑब्जेक्ट (LOB) डेटा प्रकार

बड़ी वस्तु (LOB) डेटा प्रकार बड़े डेटा आइटम जैसे कि पाठ, ग्राफिक चित्र, वीडियो क्लिप और ध्वनि तरंगों को संदर्भित करते हैं। LOB डेटा प्रकार इस डेटा के लिए कुशल, यादृच्छिक, टुकड़ा करने की अनुमति देते हैं। निम्नलिखित पूर्वनिर्धारित PL / SQL LOB डेटा प्रकार हैं -

डाटा प्रकार विवरण आकार
BFILE डेटाबेस के बाहर ऑपरेटिंग सिस्टम फ़ाइलों में बड़ी द्विआधारी वस्तुओं को संग्रहीत करने के लिए उपयोग किया जाता है। सिस्टम पर निर्भर। 4 गीगाबाइट (GB) से अधिक नहीं हो सकता।
ब्लॉब डेटाबेस में बड़ी द्विआधारी वस्तुओं को संग्रहीत करने के लिए उपयोग किया जाता है। 8 से 128 टेराबाइट्स (टीबी)
CLOB डेटाबेस में चरित्र डेटा के बड़े ब्लॉकों को संग्रहीत करने के लिए उपयोग किया जाता है। 8 से 128 टी.बी.
NCLOB डेटाबेस में NCHAR डेटा के बड़े ब्लॉक को स्टोर करने के लिए उपयोग किया जाता है। 8 से 128 टी.बी.

पीएल / एसक्यूएल उपयोगकर्ता-परिभाषित उपप्रकार

एक उपप्रकार एक अन्य डेटा प्रकार का एक सबसेट है, जिसे इसका आधार प्रकार कहा जाता है। एक उपप्रकार के आधार प्रकार के समान मान्य संचालन हैं, लेकिन इसके मान्य मानों का केवल एक सबसेट।

PL / SQL पैकेज में कई उपप्रकारों को पूर्वनिर्धारित करता है STANDARD। उदाहरण के लिए, PL / SQL उपप्रकारों को पूर्वनिर्धारित करता हैCHARACTER तथा INTEGER निम्नानुसार है -

SUBTYPE CHARACTER IS CHAR; 
SUBTYPE INTEGER IS NUMBER(38,0);

आप अपने स्वयं के उपप्रकारों को परिभाषित और उपयोग कर सकते हैं। निम्नलिखित कार्यक्रम उपयोगकर्ता परिभाषित उपप्रकार को परिभाषित और उपयोग करते हुए दिखाता है -

DECLARE 
   SUBTYPE name IS char(20); 
   SUBTYPE message IS varchar2(100); 
   salutation name; 
   greetings message; 
BEGIN 
   salutation := 'Reader '; 
   greetings := 'Welcome to the World of PL/SQL'; 
   dbms_output.put_line('Hello ' || salutation || greetings); 
END; 
/

जब एसक्यूएल प्रॉम्प्ट पर उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Hello Reader Welcome to the World of PL/SQL 
 
PL/SQL procedure successfully completed.

पीएल / एसक्यूएल में नल

PL / SQL NULL मान प्रतिनिधित्व करते हैं missing या unknown dataऔर वे एक पूर्णांक, एक चरित्र, या किसी अन्य विशिष्ट डेटा प्रकार नहीं हैं। ध्यान दें किNULL खाली डेटा स्ट्रिंग या अशक्त वर्ण मान के समान नहीं है '\0'। एक अशक्त को सौंपा जा सकता है लेकिन इसे स्वयं सहित किसी भी चीज के साथ बराबर नहीं किया जा सकता है।