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 इंगित करता है कि कोई फ़ंक्शन कोई मान नहीं देता है। |