PostgreSQL - ऑटो निरीक्षण

PostgreSQL में डेटा प्रकार छोटे , सीरियल और बिगसेरियल हैं ; ये सत्य प्रकार नहीं हैं, लेकिन विशिष्ट पहचानकर्ता कॉलम बनाने के लिए केवल एक उल्लेखनीय सुविधा है। ये कुछ अन्य डेटाबेस द्वारा समर्थित AUTO_INCREMENT संपत्ति के समान हैं।

यदि आप एक सीरियल कॉलम की इच्छा रखते हैं एक अद्वितीय बाधा या एक प्राथमिक कुंजी हो, तो इसे अब किसी अन्य डेटा प्रकार की तरह निर्दिष्ट किया जाना चाहिए।

टाइप नाम सीरियल एक पूर्णांक कॉलम बनाता है । प्रकार नाम bigserial एक bigint स्तंभ बनाता है । यदि आप तालिका के जीवनकाल में 2 से अधिक 31 पहचानकर्ताओं के उपयोग का अनुमान लगाते हैं तो बिगसरियल का उपयोग किया जाना चाहिए । प्रकार का नाम smallserial एक बनाता है SMALLINT स्तंभ।

वाक्य - विन्यास

का मूल उपयोग SERIAL डेटेप इस प्रकार है -

CREATE TABLE tablename (
   colname SERIAL
);

उदाहरण

निम्नानुसार बनाई जाने वाली कंपनी तालिका पर विचार करें -

testdb=# CREATE TABLE COMPANY(
   ID  SERIAL PRIMARY KEY,
   NAME           TEXT      NOT NULL,
   AGE            INT       NOT NULL,
   ADDRESS        CHAR(50),
   SALARY         REAL
);

अब, निम्न अभिलेखों को तालिका कंपनी में डालें -

INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'Paul', 32, 'California', 20000.00 );

INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ('Allen', 25, 'Texas', 15000.00 );

INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ('Teddy', 23, 'Norway', 20000.00 );

INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'Mark', 25, 'Rich-Mond ', 65000.00 );

INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'David', 27, 'Texas', 85000.00 );


INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'Kim', 22, 'South-Hall', 45000.00 );

INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'James', 24, 'Houston', 10000.00 );

यह तालिका में सात tuples डालेंगी। Company और Company के निम्नलिखित रिकॉर्ड होंगे -

id | name  | age | address    | salary
----+-------+-----+------------+--------
  1 | Paul  |  32 | California |  20000
  2 | Allen |  25 | Texas      |  15000
  3 | Teddy |  23 | Norway     |  20000
  4 | Mark  |  25 | Rich-Mond  |  65000
  5 | David |  27 | Texas      |  85000
  6 | Kim   |  22 | South-Hall |  45000
  7 | James |  24 | Houston    |  10000