mysql - DB load CSV into multiple tables -


UPDATE : डेटा के प्रारूप को स्पष्ट करने के लिए एक उदाहरण जोड़ा गया।

इस तरह से स्वरूपित प्रत्येक पंक्ति के साथ सीएसवी को ध्यान में रखते हुए:

  tbl1.col1, tbl1.col2, tbl1.col3, tbl1.col4, tbl1.col5, [tbl2.col1: tbl2.col2] +  

जहां [tbl2.col1: tbl2.col2] + का मतलब है कि इनमें से कोई भी जोड़ दोहराया जा सकता है

ex:

  tbl1.col1, tbl1.col2, tbl1.col3, tbl1.col4, tbl1.col5, tbl2.col1: tbl2.col2, tbl2.col1: tbl2.col2, tbl2.col1: tbl2.col2, tbl2.col1 : Tbl2.col2, tbl2.col1: tbl2.col2, tbl2.col1: tbl2.col2, tbl2.col1: tbl2.col2, tbl2.col1: tbl2.col2  

तालिकाएँ प्रत्येक पंक्ति से एक कुंजी के रूप में उपयोग करने के लिए संबंधित है जो कि ऊपर उल्लिखित किसी भी कॉलम के अतिरिक्त बनाया जाना है।

  1. mysql लोड डेटा इन्फाइल का उपयोग करने का कोई तरीका है डेटा को दो अलग-अलग तालिकाओं में लोड करने के लिए?
  2. यदि नहीं, तो यूनिक्स कमांड लाइन उपकरण इस के लिए सबसे उपयुक्त क्यों होंगे?

नहीं, सीधे नहीं। लोड डेटा केवल एक तालिका या विभाजन तालिका में सम्मिलित कर सकता है।

आप क्या कर सकते हैं डेटा को एक स्टेजिंग तालिका में लोड करें, फिर डालें में व्यक्तिगत कॉलम का चयन करें 2 अंतिम टेबल आपको substring_index की आवश्यकता हो सकती है, अगर आप tbl2 के मानों के लिए अलग-अलग सीमांकक का उपयोग कर रहे हैं लाइन नंबर स्टेजिंग तालिका में एक ऑटो वृद्धिशील कॉलम द्वारा नियंत्रित किया जाता है (सबसे आसान तरीका है ऑटो स्तम्भ को अंतिम रूप से स्टेजिंग तालिका की परिभाषा में करना है)।

प्रारूप बिल्कुल स्पष्ट नहीं है, और सबसे अच्छा किया जाता है W / perl / php / python, लेकिन अगर आप वास्तव में शेल टूल्स का उपयोग करना चाहते हैं:

  cut -d, -f 1-5 फ़ाइल | Awk -F, '{print nr "," $ 0}' & gt; टेबल 1 कट-डी, -f 6- फाइल | Sed 's, \:, \, g' | \ Awk -F, '{i = 1; जबकि (i & lt; = nf) {प्रिंट एनआर "," $ (i) "," $ (i + 1); I + = 2;}} '& gt; तालिका 2  

यह इन सामग्रियों के साथ तालिका 1 और तालिका 2 फाइल बनाता है:

  1, tbl1.col1, tbl1.col2, tbl1.col3, tbl1.col4 , Tbl1.col5 2, tbl1.col1, tbl1.col2, tbl1.col3, tbl1.col4, tbl1.col5 3, tbl1.col1, tbl1.col2, tbl1.col3, tbl1.col4, tbl1.col5  

और

<पूर्व> 1, tbl2.col1, tbl2.col2 1, tbl2.col1, tbl2.col2 2, tbl2.col1, tbl2.col2 2, tbl2.col1 , Tbl2.col2 3, tbl2.col1, tbl2.col2 3, tbl2.col1, tbl2.col2

Comments

Popular posts from this blog

php - multilevel menu with multilevel array -

c# - TypeConverter in propertygrid only converts from string, not to -

jQuery UI: Datepicker month format -