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

इनपुट सीएसवी से केवल कुछ कॉलम कॉपी करें?

मुझे नहीं पता कि आपको वह सिंटैक्स कहां से मिला, लेकिन COPY उस तरह के कॉलम उपनामों की सूची नहीं लेता है। सहायता देखें:

COPY table_name [ ( column_name [, ...] ) ]
    FROM { 'filename' | PROGRAM 'command' | STDIN }
    [ [ WITH ] ( option [, ...] ) ]

(AS सूचीबद्ध विकल्पों में से एक नहीं है; पूरा आउटपुट देखने के लिए \d copy चलाएं psql में, या copy . के लिए मैनुअल देखें आदेश ऑनलाइन)।

COPY में मैपिंग की कोई सुविधा नहीं है जो आपको इनपुट सीएसवी के केवल कुछ कॉलम पढ़ने देता है। यह वास्तव में उपयोगी होगा, लेकिन अभी तक इसे लागू करने के लिए किसी के पास समय/ब्याज/वित्त पोषण नहीं था। यह वास्तव में कई डेटा रूपांतरण/फ़िल्टरिंग कार्यों में से केवल एक है जो लोग वैसे भी चाहते हैं।

PostgreSQL COPY में दी गई कॉलम-सूची की अपेक्षा करता है एक ही क्रम में होना, बाएं से दाएं, जैसा कि CSV फ़ाइल में है, और प्रविष्टियों की संख्या उतनी ही है जितनी CSV फ़ाइल में कॉलम हैं। तो अगर आप लिखते हैं:

COPY con (date,kgs)

तब PostgreSQL बिल्कुल दो कॉलम . के साथ इनपुट CSV की अपेक्षा करेगा . यह "date" . के लिए पहले csv कॉलम का उपयोग करेगा "kgs" . के लिए टेबल कॉलम और दूसरा csv कॉलम टेबल कॉलम। इससे कोई फर्क नहीं पड़ता कि सीएसवी हेडर क्या हैं, यदि आप WITH (FORMAT CSV, HEADER ON) निर्दिष्ट करते हैं तो उन्हें अनदेखा कर दिया जाता है , या यदि आप HEADER . निर्दिष्ट नहीं करते हैं, तो इसे सामान्य डेटा पंक्तियों के रूप में माना जाता है ।

PostgreSQL 9.4 FROM PROGRAM जोड़ता है करने के लिए COPY , ताकि आप फ़ाइल को पढ़ने और उसे फ़िल्टर करने के लिए शेल कमांड चला सकें। एक साधारण पायथन या पर्ल स्क्रिप्ट काम करेगी।

यदि यह एक छोटी फ़ाइल है, तो बस अपनी पसंद की स्प्रेडशीट में एक सीएसवी फ़ाइल के रूप में एक प्रति खोलें, अवांछित कॉलम हटाएं, और इसे सहेजें, इसलिए केवल date और kgs कॉलम बने हुए हैं।

वैकल्पिक रूप से, COPY एक स्टेजिंग टेबल पर जिसमें CSV . के समान सभी कॉलम हों , फिर एक INSERT INTO ... SELECT केवल वांछित डेटा को वास्तविक लक्ष्य तालिका में स्थानांतरित करने के लिए।




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. मैं कपड़े के साथ एक पोस्टग्रेस्क्ल उपयोगकर्ता कैसे बना सकता हूं

  2. PostgreSQL में सिंगल SQL में पैरेंट टेबल में सिंगल रो और फिर चाइल्ड टेबल में मल्टीपल रो कैसे डालें?

  3. डेटटाइम ऑब्जेक्ट पर अलग-अलग टाइमज़ोन_टाइप्स

  4. पोस्टग्रेज के साथ समस्या ALTER TABLE

  5. PostgreSQL 11:विभाजन पैच के लिए पैच समीक्षक