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

पोस्टग्रेज़ का उपयोग करके तालिका में दूसरे या तीसरे कॉलम के बाद तालिका में एक नया कॉलम कैसे जोड़ें?

नहीं, ऐसा करने का कोई सीधा तरीका नहीं है। और इसके लिए एक कारण है - प्रत्येक क्वेरी को उन सभी क्षेत्रों को सूचीबद्ध करना चाहिए जिनकी उसे जरूरत है, जिस क्रम में (और प्रारूप आदि) उसे उनकी आवश्यकता है, इस प्रकार एक तालिका में स्तंभों का क्रम महत्वहीन हो जाता है।

अगर आपको वास्तव में ऐसा करने की ज़रूरत है तो मैं एक समाधान के बारे में सोच सकता हूं:

  • विचाराधीन तालिका का विवरण डंप करें और सहेजें (pg_dump --schema-only --table=<schema.table> ... का उपयोग करके) )
  • सेव की गई परिभाषा में वह कॉलम जोड़ें जहां आप उसे चाहते हैं
  • सेव की गई परिभाषा में तालिका का नाम बदलें ताकि जब आप इसे बनाने का प्रयास करें तो पुरानी तालिका के नाम से टकराव न हो
  • इस परिभाषा का उपयोग करके नई तालिका बनाएं
  • 'INSERT INTO <new_table> का उपयोग करके पुरानी तालिका के डेटा के साथ नई तालिका को पॉप्युलेट करें फ़ील्ड 1, फ़ील्ड 2 चुनें, <default_for_new_field> , फ़ील्ड3,... <old_table> . से ';
  • पुरानी तालिका का नाम बदलें
  • नई तालिका का नाम बदलकर मूल नाम कर दें
  • यह सुनिश्चित करने के बाद कि सब कुछ ठीक है, पुरानी, ​​​​बदली गई तालिका को अंत में छोड़ दें


  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. क्लाउड विक्रेता डीप-डाइव:Google क्लाउड प्लेटफ़ॉर्म (GCP) पर PostgreSQL

  3. रिकॉर्ड के कॉलम के माध्यम से लूप

  4. PostgreSQL में क्वेरी ऑप्टिमाइज़ेशन। मूल बातें समझाएं - भाग 2

  5. पोस्टग्रेज में फ़ील्ड का डेटाटाइप चुनें