PostgreSQL - डेटा प्रकार

इस अध्याय में, हम PostgreSQL में उपयोग किए जाने वाले डेटा प्रकारों के बारे में चर्चा करेंगे। तालिका बनाते समय, प्रत्येक स्तंभ के लिए, आप एक डेटा प्रकार निर्दिष्ट करते हैं, अर्थात, टेबल फ़ील्ड में आप किस प्रकार का डेटा संग्रहीत करना चाहते हैं।

इससे कई लाभ मिलते हैं -

  • Consistency - एक ही डेटा प्रकार के स्तंभों के विरुद्ध संचालन लगातार परिणाम देते हैं और आमतौर पर सबसे तेज़ होते हैं।

  • Validation - डेटा प्रकारों का समुचित उपयोग डेटा के प्रारूप सत्यापन और डेटा प्रकार के दायरे से बाहर डेटा की अस्वीकृति का तात्पर्य करता है।

  • Compactness - एक स्तंभ के रूप में एक ही प्रकार के मूल्य को संग्रहीत कर सकते हैं, यह एक कॉम्पैक्ट तरीके से संग्रहीत किया जाता है।

  • Performance- डेटा प्रकारों का उचित उपयोग डेटा का सबसे कुशल भंडारण देता है। संग्रहीत मूल्यों को जल्दी से संसाधित किया जा सकता है, जो प्रदर्शन को बढ़ाता है।

PostgreSQL डेटा प्रकारों की एक विस्तृत सेट का समर्थन करता है। इसके अलावा, उपयोगकर्ता क्रिएट टाइप SQL कमांड का उपयोग करके अपने स्वयं के कस्टम डेटा प्रकार बना सकते हैं । PostgreSQL में विभिन्न प्रकार के डेटा श्रेणी हैं। उनकी चर्चा नीचे की गई है।

संख्यात्मक प्रकार

न्यूमेरिक प्रकारों में दो-बाइट, चार-बाइट और आठ-बाइट पूर्णांक, चार-बाइट और आठ-बाइट फ़्लोटिंग-पॉइंट संख्या और चयन-सटीक दशमलव होते हैं। निम्न तालिका उपलब्ध प्रकारों को सूचीबद्ध करती है।

नाम भंडारण का आकार विवरण रेंज
SMALLINT 2 बाइट्स छोटी श्रेणी का पूर्णांक -32768 से +32767
पूर्णांक 4 निवाले पूर्णांक के लिए विशिष्ट विकल्प -2147483648 से +2147483647
bigint 8 बाइट्स बड़ी श्रेणी के पूर्णांक -9223372036854775808 से 9223372036854775807
दशमलव परिवर्तनशील उपयोगकर्ता-निर्दिष्ट परिशुद्धता, सटीक दशमलव बिंदु से पहले 131072 अंक तक; दशमलव बिंदु के बाद 16383 अंकों तक
संख्यात्मक परिवर्तनशील उपयोगकर्ता-निर्दिष्ट परिशुद्धता, सटीक दशमलव बिंदु से पहले 131072 अंक तक; दशमलव बिंदु के बाद 16383 अंकों तक
असली 4 निवाले चर परिशुद्धता, अयथार्थ 6 दशमलव अंक सटीक
दोहरी सुनिश्चितता 8 बाइट्स चर परिशुद्धता, अयथार्थ 15 दशमलव अंक सटीक
smallserial 2 बाइट्स छोटा ऑटोनॉइरिमेंटिंग पूर्णांक 1 से 32767 तक
धारावाहिक 4 निवाले स्वत: अंकन पूर्णांक 1 से 2147483647
bigserial 8 बाइट्स बड़े स्वयंभू पूर्णांक 1 से 922337203685474780807

मौद्रिक प्रकार

पैसा प्रकार एक निश्चित आंशिक परिशुद्धता के साथ एक मुद्रा राशि संग्रहीत करता है। के मान सांख्यिक, पूर्णांक, और bigint डेटा प्रकार के लिए डाली जा सकती है पैसा । राउंडिंग त्रुटियों की क्षमता के कारण पैसे को संभालने के लिए फ्लोटिंग पॉइंट नंबरों का उपयोग करने की अनुशंसा नहीं की जाती है।

नाम भंडारण का आकार विवरण रेंज
पैसे 8 बाइट्स मुद्रा मूल्य -92233720368547758.08 से +92233720368547758.07

चरित्र प्रकार

नीचे दी गई तालिका पोस्टग्रेएसक्यूएल में उपलब्ध सामान्य-उद्देश्य चरित्र प्रकारों को सूचीबद्ध करती है।

एस। नाम और विवरण
1

character varying(n), varchar(n)

चर-लंबाई सीमा के साथ

2

character(n), char(n)

निश्चित-लंबाई, खाली गद्देदार

3

text

चर असीमित लंबाई

बाइनरी डेटा प्रकार

Bytea डेटा प्रकार नीचे दी गई सारणी में के रूप में द्विआधारी तार के भंडारण की अनुमति देता है।

नाम भंडारण का आकार विवरण
bytea 1 या 4 बाइट्स के अलावा वास्तविक बाइनरी स्ट्रिंग चर-लंबाई बाइनरी स्ट्रिंग

दिनांक / समय के प्रकार

PostgreSQL SQL दिनांक और समय प्रकार का एक पूरा सेट का समर्थन करता है, जैसा कि नीचे तालिका में दिखाया गया है। तिथियां गिगोरियन कैलेंडर के अनुसार गिनी जाती हैं। यहाँ, सभी प्रकार के संकल्प हैं1 microsecond / 14 digits के सिवाय date प्रकार, जिसका संकल्प है day

नाम भंडारण का आकार विवरण कम मूल्य उच्च मूल्य
टाइमस्टैम्प [(पी)] [समय क्षेत्र के बिना] 8 बाइट्स दिनांक और समय दोनों (समय क्षेत्र नहीं) 4713 ई.पू. 294276 ई
TIMESTAMPTZ 8 बाइट्स समय क्षेत्र के साथ दिनांक और समय दोनों 4713 ई.पू. 294276 ई
दिनांक 4 निवाले तारीख (दिन का कोई समय नहीं) 4713 ई.पू. 5874897 ई
समय [(पी)] [समय क्षेत्र के बिना] 8 बाइट्स दिन का समय (कोई तिथि नहीं) 00:00:00 24:00:00
समय क्षेत्र के साथ समय [(पी)] 12 बाइट्स केवल दिन का समय, समय क्षेत्र के साथ 00: 00: 00 + 1459 24: 00: 00-1459
अंतराल [क्षेत्र] [(पी)] 12 बाइट्स समय अंतराल -178000000 वर्ष 178000000 वर्ष

बूलियन प्रकार

PostgreSQL मानक SQL प्रकार बूलियन प्रदान करता है। बूलियन डेटा प्रकार में स्थिति सही , गलत और एक तीसरी स्थिति हो सकती है, अज्ञात , जो SQL नल मान द्वारा दर्शाया गया है।

नाम भंडारण का आकार विवरण
बूलियन 1 बाइट सत्य या असत्य की अवस्था

प्रगणित प्रकार

Enumerated (enum) प्रकार वे डेटा प्रकार होते हैं जिनमें एक स्थिर, आदेशित मान शामिल होता है। वे कई प्रोग्रामिंग भाषाओं में समर्थित enum प्रकारों के बराबर हैं।

अन्य प्रकारों के विपरीत, Enumerated Types को CREATE TYPE कमांड का उपयोग करके बनाया जाना चाहिए। इस प्रकार का उपयोग स्थिर, ऑर्डर किए गए मानों के सेट को संग्रहीत करने के लिए किया जाता है। उदाहरण के लिए कम्पास दिशाएँ, जैसे, उत्तर, दक्षिण, पूर्व और पश्चिम या सप्ताह के दिन जैसा कि नीचे दिखाया गया है -

CREATE TYPE week AS ENUM ('Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun');

एक बार बनाया गया, किसी भी अन्य प्रकार की तरह इस्तेमाल किया जा सकता है।

ज्यामितीय प्रकार

ज्यामितीय डेटा प्रकार दो आयामी स्थानिक वस्तुओं का प्रतिनिधित्व करते हैं। सबसे मौलिक प्रकार, बिंदु, अन्य सभी प्रकारों के लिए आधार बनाता है।

नाम भंडारण का आकार प्रतिनिधित्व विवरण
बिंदु 16 बाइट्स एक विमान पर इंगित करें (एक्स, वाई)
लाइन 32 बाइट्स अनंत रेखा (पूरी तरह से लागू नहीं) ((X1, y1), (x2, y2))
lseg 32 बाइट्स परिमित रेखा खंड ((X1, y1), (x2, y2))
डिब्बा 32 बाइट्स आयताकार बॉक्स ((X1, y1), (x2, y2))
पथ 16 + 16n बाइट्स बंद पथ (बहुभुज के समान) ((X1, y1), ...)
पथ 16 + 16n बाइट्स खुला रास्ता [(X1, y1), ...]
बहुभुज 40 + 16N बहुभुज (बंद पथ के समान) ((X1, y1), ...)
वृत्त 24 बाइट्स वृत्त <(x, y), r> (केंद्र बिंदु और त्रिज्या)

नेटवर्क पता प्रकार

PostgreSQL IPv4, IPv6, और MAC पतों को संग्रहीत करने के लिए डेटा प्रकार प्रदान करता है। नेटवर्क पते को संग्रहीत करने के लिए सादे पाठ प्रकारों के बजाय इन प्रकारों का उपयोग करना बेहतर है, क्योंकि ये प्रकार इनपुट त्रुटि जाँच और विशेष ऑपरेटर और फ़ंक्शन प्रदान करते हैं।

नाम भंडारण का आकार विवरण
सीआईडीआर 7 या 19 बाइट्स IPv4 और IPv6 नेटवर्क
मंत्रिमंडल 7 या 19 बाइट्स IPv4 और IPv6 होस्ट और नेटवर्क
MACADDR 6 बाइट्स मैक पते

बिट स्ट्रिंग प्रकार

बिट स्ट्रिंग प्रकार बिट मास्क को स्टोर करने के लिए उपयोग किए जाते हैं। वे या तो 0 या 1. दो SQL बिट प्रकार हैं:bit(n) तथा bit varying(n), जहाँ n एक धनात्मक पूर्णांक है।

पाठ खोज प्रकार

यह प्रकार पूर्ण पाठ खोज का समर्थन करता है, जो एक क्वेरी से मेल खाने वाले लोगों का पता लगाने के लिए प्राकृतिक भाषा के दस्तावेजों के संग्रह के माध्यम से खोज करने की गतिविधि है। इसके लिए दो डेटा प्रकार हैं -

एस। नाम और विवरण
1

tsvector

यह अलग-अलग शब्दों की एक क्रमबद्ध सूची है, जिसे एक ही शब्द के विभिन्न वेरिएंट्स में विलय करने के लिए सामान्यीकृत किया गया है, जिसे "लेक्समेस" कहा जाता है।

2

tsquery

यह उन भंडारों को संग्रहीत करता है जिनकी खोज की जानी है, और उन्हें बूलियन ऑपरेटरों और (और) के सम्मान में जोड़ती है, (या और ! (नहीं)। कोष्ठकों का उपयोग ऑपरेटरों के समूहन को लागू करने के लिए किया जा सकता है।

UUID प्रकार

एक UUID (यूनिवर्सली यूनिक आइडेंटिफ़ायर) को लोअर-केस हेक्साडेसिमल अंकों के अनुक्रम के रूप में लिखा जाता है, कई समूहों में हाइफ़न, विशेष रूप से आठ अंकों का एक समूह, जिसके बाद चार अंकों के तीन समूह होते हैं, उसके बाद 12 अंकों का एक समूह होता है। 128 बिट्स का प्रतिनिधित्व करने वाले कुल 32 अंक।

UUID का एक उदाहरण है - 550e8400-e29b-41d4-a716-446655440000

XML प्रकार

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

XMLPARSE (DOCUMENT '<?xml version="1.0"?>
<tutorial>
<title>PostgreSQL Tutorial </title>
   <topics>...</topics>
</tutorial>')

XMLPARSE (CONTENT 'xyz<foo>bar</foo><bar>foo</bar>')

JSON प्रकार

Json डेटा प्रकार JSON (जावास्क्रिप्ट ऑब्जेक्ट नोटेशन) डाटा स्टोर करने के लिए इस्तेमाल किया जा सकता है। इस तरह के डेटा को पाठ के रूप में भी संग्रहीत किया जा सकता है , लेकिन json डेटा प्रकार के पास यह जांचने का लाभ है कि प्रत्येक संग्रहीत मूल्य एक वैध JSON मान है। संबंधित सहायता कार्य भी उपलब्ध हैं, जिनका उपयोग सीधे JSON डेटा प्रकार को संभालने के लिए किया जा सकता है।

उदाहरण उदाहरण परिणाम
array_to_json ( '{{1,5}, {99,100}}' :: पूर्णांक []) [[1,5], [99,100]]
row_to_json (पंक्ति (1, 'foo')) { "F1": 1, "F2": "foo"}

सरणी प्रकार

PostgreSQL एक तालिका के एक स्तंभ को एक चर लंबाई बहुआयामी सरणी के रूप में परिभाषित करने का अवसर देता है। किसी भी अंतर्निहित या उपयोगकर्ता-परिभाषित आधार प्रकार, एनम प्रकार या समग्र प्रकार की सारणियां बनाई जा सकती हैं।

ऐरे की घोषणा

सरणी प्रकार के रूप में घोषित किया जा सकता है

CREATE TABLE monthly_savings (
   name text,
   saving_per_quarter integer[],
   scheme text[][]
);

या "ARRAY" कीवर्ड का उपयोग करके

CREATE TABLE monthly_savings (
   name text,
   saving_per_quarter integer ARRAY[4],
   scheme text[][]
);

मूल्यों को सम्मिलित करना

सरणी मानों को शाब्दिक स्थिरांक के रूप में डाला जा सकता है, घुंघराले ब्रेस के भीतर तत्व मानों को संलग्न करते हुए और उन्हें अल्पविराम द्वारा अलग किया जाता है। एक उदाहरण नीचे दिखाया गया है -

INSERT INTO monthly_savings 
VALUES (‘Manisha’, 
‘{20000, 14600, 23500, 13250}’, 
‘{{“FD”, “MF”}, {“FD”, “Property”}}’);

अभिगम

Arrays तक पहुँचने का एक उदाहरण नीचे दिखाया गया है। नीचे दी गई कमांड उन व्यक्तियों का चयन करेगी जिनकी बचत चौथी तिमाही की तुलना में दूसरी तिमाही में अधिक है।

SELECT name FROM monhly_savings WHERE saving_per_quarter[2] > saving_per_quarter[4];

संशोधन संशोधित करना

नीचे दिए गए तरीके से संशोधित सरणियों का एक उदाहरण दिया गया है।

UPDATE monthly_savings SET saving_per_quarter = '{25000,25000,27000,27000}'
WHERE name = 'Manisha';

या ARRAY अभिव्यक्ति सिंटैक्स का उपयोग कर -

UPDATE monthly_savings SET saving_per_quarter = ARRAY[25000,25000,27000,27000]
WHERE name = 'Manisha';

Arrays खोजना

खोज सरणियों का एक उदाहरण नीचे दिखाया गया है।

SELECT * FROM monthly_savings WHERE saving_per_quarter[1] = 10000 OR
saving_per_quarter[2] = 10000 OR
saving_per_quarter[3] = 10000 OR
saving_per_quarter[4] = 10000;

यदि सरणी का आकार ज्ञात है, तो ऊपर दी गई खोज विधि का उपयोग किया जा सकता है। एल्स, निम्न उदाहरण दिखाता है कि जब आकार ज्ञात नहीं है तो कैसे खोजा जाए।

SELECT * FROM monthly_savings WHERE 10000 = ANY (saving_per_quarter);

समग्र प्रकार

यह प्रकार फ़ील्ड नामों और उनके डेटा प्रकारों की सूची का प्रतिनिधित्व करता है, अर्थात, किसी तालिका की एक पंक्ति या रिकॉर्ड की संरचना।

समग्र प्रकारों की घोषणा

निम्न उदाहरण से पता चलता है कि एक मिश्रित प्रकार कैसे घोषित किया जाए

CREATE TYPE inventory_item AS (
   name text,
   supplier_id integer,
   price numeric
);

यह डेटा प्रकार नीचे दी गई तालिका में उपयोग किया जा सकता है -

CREATE TABLE on_hand (
   item inventory_item,
   count integer
);

समग्र मूल्य इनपुट

समग्र मूल्यों को शाब्दिक निरंतर के रूप में डाला जा सकता है, कोष्ठक के भीतर क्षेत्र मूल्यों को संलग्न करना और उन्हें अल्पविराम द्वारा अलग करना। एक उदाहरण नीचे दिखाया गया है -

INSERT INTO on_hand VALUES (ROW('fuzzy dice', 42, 1.99), 1000);

यह ऊपर सूचीबद्ध इन्वेंट्री_इटेम के लिए मान्य है। ROW कीवर्ड वास्तव में वैकल्पिक है जब तक कि आपके पास अभिव्यक्ति में एक से अधिक फ़ील्ड हैं।

समग्र प्रकार तक पहुँचना

किसी कंपोजिट कॉलम के क्षेत्र तक पहुँचने के लिए, फ़ील्ड नाम के बाद एक डॉट का उपयोग करें, जैसे टेबल नाम से फ़ील्ड का चयन करना। उदाहरण के लिए, हमारे on_hand उदाहरण तालिका से कुछ उपक्षेत्रों का चयन करने के लिए, क्वेरी निम्नानुसार दिखाई जाएगी -

SELECT (item).name FROM on_hand WHERE (item).price > 9.99;

आप तालिका के नाम का भी उपयोग कर सकते हैं (उदाहरण के लिए एक बहु क्वेरी में), इस तरह -

SELECT (on_hand.item).name FROM on_hand WHERE (on_hand.item).price > 9.99;

रेंज के प्रकार

श्रेणी प्रकार डेटा प्रकारों का प्रतिनिधित्व करते हैं जो डेटा की एक सीमा का उपयोग करते हैं। रेंज प्रकार असतत रेंज हो सकता है (उदाहरण के लिए, सभी पूर्णांक मान 1 से 10) या निरंतर पर्वतमाला (जैसे, किसी भी समय 10:00 पूर्वाह्न से 11:00 बजे के बीच)।

उपलब्ध रेंज प्रकारों में निम्नलिखित रेंज शामिल हैं -

  • int4range - पूर्णांक की सीमा

  • int8range - बिगिन की सीमा

  • numrange - संख्यात्मक की सीमा

  • tsrange - समय क्षेत्र के बिना टाइमस्टैम्प की सीमा

  • tstzrange - समय क्षेत्र के साथ टाइमस्टैम्प की सीमा

  • daterange - तारीख की सीमा

नए प्रकार की श्रेणियां उपलब्ध कराने के लिए कस्टम श्रेणी प्रकार बनाए जा सकते हैं, जैसे कि IP पता पर्वतमाला एक बेस के रूप में inet प्रकार का उपयोग करता है, या फ्लोट डेटा प्रकार का उपयोग आधार के रूप में फ़्लोट श्रेणी करता है।

रेंज प्रकार क्रमशः [] और () वर्णों का उपयोग करके समावेशी और अनन्य श्रेणी की सीमाओं का समर्थन करते हैं। उदाहरण के लिए '[4,9)' सभी पूर्णांकों को दर्शाता है जो 4 से शुरू होते हैं और 4 तक होते हैं, लेकिन 9 शामिल नहीं होते हैं।

वस्तु पहचानकर्ता प्रकार

ऑब्जेक्ट पहचानकर्ता (OID) आंतरिक रूप से PostgreSQL द्वारा विभिन्न सिस्टम तालिकाओं के लिए प्राथमिक कुंजी के रूप में उपयोग किए जाते हैं। यदि OIDS निर्दिष्ट है या default_with_oids कॉन्फ़िगरेशन चर सक्षम है, तभी, ऐसे मामलों में उपयोगकर्ता-निर्मित तालिकाओं में OID जोड़े जाते हैं। निम्न तालिका कई अन्य प्रकारों को सूचीबद्ध करती है। विशेष इनपुट और आउटपुट रूटीन को छोड़कर OID उर्फ ​​प्रकारों का अपना कोई संचालन नहीं है।

नाम संदर्भ विवरण मान उदाहरण
OID कोई भी संख्यात्मक वस्तु पहचानकर्ता 564,182
regproc pg_proc समारोह का नाम योग
regprocedure pg_proc तर्क प्रकार के साथ कार्य करें योग (int4)
regoper pg_operator ऑपरेटर का नाम +
regoperator pg_operator तर्क प्रकार के साथ ऑपरेटर * (पूर्णांक, पूर्णांक) या - (पूर्णांक, पूर्णांक)
regclass pg_class संबंध का नाम pg_type
regtype pg_type डेटा प्रकार नाम पूर्णांक
regconfig pg_ts_config पाठ खोज कॉन्फ़िगरेशन अंग्रेज़ी
regdictionary pg_ts_dict पाठ खोज शब्दकोश सरल

छद्म प्रकार

PostgreSQL प्रकार प्रणाली में कई विशेष प्रयोजन प्रविष्टियाँ होती हैं जिन्हें सामूहिक रूप से छद्म प्रकार कहा जाता है। एक छद्म प्रकार का उपयोग स्तंभ डेटा प्रकार के रूप में नहीं किया जा सकता है, लेकिन इसका उपयोग फ़ंक्शन के तर्क या परिणाम प्रकार को घोषित करने के लिए किया जा सकता है।

नीचे दी गई तालिका मौजूदा छद्म प्रकारों को सूचीबद्ध करती है।

एस। नाम और विवरण
1

any

इंगित करता है कि एक फ़ंक्शन किसी भी इनपुट डेटा प्रकार को स्वीकार करता है।

2

anyelement

इंगित करता है कि एक फ़ंक्शन किसी भी डेटा प्रकार को स्वीकार करता है।

3

anyarray

इंगित करता है कि एक फ़ंक्शन किसी भी सरणी डेटा प्रकार को स्वीकार करता है।

4

anynonarray

इंगित करता है कि एक फ़ंक्शन किसी भी गैर-सरणी डेटा प्रकार को स्वीकार करता है।

5

anyenum

इंगित करता है कि एक फ़ंक्शन किसी भी एनम डेटा प्रकार को स्वीकार करता है।

6

anyrange

इंगित करता है कि एक फ़ंक्शन किसी भी रेंज डेटा प्रकार को स्वीकार करता है।

7

cstring

इंगित करता है कि कोई फ़ंक्शन शून्य-टर्म सी स्ट्रिंग को स्वीकार या वापस करता है।

8

internal

इंगित करता है कि एक फ़ंक्शन सर्वर-आंतरिक डेटा प्रकार को स्वीकार या वापस करता है।

9

language_handler

एक प्रक्रियात्मक भाषा कॉल हैंडलर को भाषा_हैंडलर वापस करने के लिए घोषित किया जाता है।

10

fdw_handler

एक विदेशी-डेटा रैपर हैंडलर को fdw_handler वापस करने के लिए घोषित किया जाता है।

1 1

record

एक अनिर्दिष्ट पंक्ति प्रकार लौटाने वाले फ़ंक्शन को पहचानता है।

12

trigger

ट्रिगर वापस करने के लिए एक ट्रिगर फ़ंक्शन घोषित किया जाता है।

13

void

इंगित करता है कि कोई फ़ंक्शन कोई मान नहीं देता है।