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

PostgreSQL में एक ऑटो इंक्रीमेंट प्राथमिक कुंजी को कैसे परिभाषित करें

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

सीरियल डेटा प्रकार का उपयोग करना

Postgres में प्राथमिक कुंजी जोड़ने के लिए अब तक की सबसे सरल और सबसे सामान्य तकनीक SERIAL का उपयोग करना है या BIGSERIAL डेटा प्रकार जब CREATING एक नई तालिका। जैसा कि आधिकारिक दस्तावेज में बताया गया है, SERIAL एक वास्तविक डेटा प्रकार नहीं है, लेकिन केवल शॉर्टहैंड नोटेशन है जो पोस्टग्रेज़ को निर्दिष्ट कॉलम के लिए एक ऑटो इंक्रीमेंटेड, विशिष्ट पहचानकर्ता बनाने के लिए कहता है।

नीचे हम अपनी सरल books बनाएंगे उपयुक्त SERIAL . के साथ तालिका प्राथमिक कुंजी के लिए डेटा प्रकार।

CREATE TABLE books (
  id              SERIAL PRIMARY KEY,
  title           VARCHAR(100) NOT NULL,
  primary_author  VARCHAR(100) NULL
);

बस हमारी id . सेट करके SERIAL . के रूप में कॉलम PRIMARY KEY के साथ संलग्न है, Postgres पर्दे के पीछे के सभी जटिल कार्यों को संभाल लेगा और स्वचालित रूप से हमारी id को बढ़ा देगा। प्रत्येक INSERT . के लिए एक अद्वितीय, प्राथमिक कुंजी मान वाला स्तंभ ।

कस्टम अनुक्रम का उपयोग करना

कुछ दुर्लभ मामलों में, SERIAL . में निर्मित मानक वृद्धिशील प्रकृति और BIGSERIAL डेटा प्रकार आपकी आवश्यकताओं के अनुरूप नहीं हो सकते हैं। इन मामलों में, आप एक कस्टम SEQUENCE बनाकर अपने कॉलम के लिए वही ऑटो इंक्रीमेंटेड प्राइमरी की फंक्शनलिटी कर सकते हैं। , Oracle के पुराने संस्करण में प्रयुक्त विधि के समान।

शायद हम विशेष रूप से सम संख्याओं के शौकीन हैं, लेकिन 100 से छोटी किसी भी चीज़ के लिए एक मजबूत अरुचि रखते हैं, इसलिए हम केवल यह चाहते हैं कि प्रत्येक प्रविष्टि के लिए हमारी प्राथमिक कुंजी को 100 से शुरू करके दो से बढ़ाया जाए। यह एक कस्टम SEQUENCE . के साथ पूरा किया जा सकता है इस तरह:

CREATE SEQUENCE books_sequence
  start 2
  increment 2;

अब जब हम INSERT हमारी books . में एक नया रिकॉर्ड तालिका में, हमें nextval('books_sequence') के साथ हमारे अनुक्रम के अगले मान का मूल्यांकन करने की आवश्यकता है और इसे हमारे id . के रूप में उपयोग करें ।

INSERT INTO books
  (id, title, primary_author)
VALUES
  (nextval('books_sequence'), 'The Hobbit', 'Tolkien');

SEQUENCES minvalue . जैसे विकल्पों के साथ, यदि वांछित हो, तो इसे और भी अधिक मसालेदार बनाया जा सकता है और maxvalue निश्चित रूप से चरम मूल्यों को इंगित करता है, और यहां तक ​​कि CYCLE , जो अनुक्रम को maxvalue . तक पहुंचने के बाद "चारों ओर लूप" करने की अनुमति देता है , start . पर वापस लौटना मूल्य और फिर से चढ़ाई शुरू करना। अधिक जानकारी आधिकारिक दस्तावेज़ीकरण में पाई जा सकती है।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PostgreSQL में सेकंड में टाइमस्टैम्प के बीच अंतर खोजें

  2. मैं हेरोकू में कॉलम प्रकार कैसे बदलूं?

  3. कैसे pg_typeof () PostgreSQL में काम करता है

  4. पोस्टग्रेएसक्यूएल पैरामीटराइज्ड ऑर्डर बाय / लिमिट इन टेबल फंक्शन

  5. एकाधिक थ्रेड्स का उपयोग करके फ़ाइल लिखना