MySQL - डेटाबेस निर्यात

पाठ फ़ाइल में तालिका डेटा निर्यात करने का सबसे सरल तरीका है SELECT...INTO OUTFILE कथन जो निर्यात करता है वह सीधे सर्वर होस्ट पर फ़ाइल में परिणाम करता है।

डेटा का चयन करें के साथ निर्यात ... OUTFILE वक्तव्य

इस कथन का सिंटैक्स एक नियमित रूप से जोड़ता है SELECT के साथ कमान INTO OUTFILE filenameअतं मै। डिफ़ॉल्ट आउटपुट स्वरूप वही है जो LOAD DATA कमांड के लिए है। इसलिए, निम्न कथन निर्यात करता हैtutorials_tbl में टेबल /tmp/tutorials.txt टैब-सीमांकित के रूप में, पंक्तिबद्ध-समाप्त फ़ाइल।

mysql> SELECT * FROM tutorials_tbl 
   -> INTO OUTFILE '/tmp/tutorials.txt';

आप कॉलम और रिकॉर्ड को कैसे उद्धृत और परिसीमन करें, यह बताने के लिए विभिन्न विकल्पों का उपयोग करके आउटपुट स्वरूप को बदल सकते हैं। CRLF- समाप्त लाइनों के साथ CSV प्रारूप में tutorial_tbl तालिका को निर्यात करने के लिए, निम्न कोड का उपयोग करें।

mysql> SELECT * FROM passwd INTO OUTFILE '/tmp/tutorials.txt'
   -> FIELDS TERMINATED BY ',' ENCLOSED BY '"'
   -> LINES TERMINATED BY '\r\n';

SELECT ... INTO OUTFILE निम्नलिखित गुण हैं -

  • आउटपुट फ़ाइल सीधे MySQL सर्वर द्वारा बनाई गई है, इसलिए फ़ाइलनाम को इंगित करना चाहिए कि आप कहाँ चाहते हैं कि फ़ाइल सर्वर होस्ट पर लिखी जाए। करने के लिए अनुरूप बयान का कोई स्थानीय संस्करण हैLOCAL का संस्करण LOAD DATA

  • आपके पास होना चाहिए MySQL FILE निष्पादित करने का विशेषाधिकार SELECT ... INTO बयान।

  • आउटपुट फ़ाइल पहले से मौजूद नहीं होनी चाहिए। यह MySQL को क्लोबबेरिंग फ़ाइलों से रोकता है जो महत्वपूर्ण हो सकती हैं।

  • आपके पास सर्वर होस्ट पर लॉगिन खाता होना चाहिए या उस होस्ट से फ़ाइल पुनर्प्राप्त करने का कोई तरीका होना चाहिए। अन्यथाSELECT ... INTO OUTFILE कमांड आपके लिए सबसे अधिक महत्वपूर्ण होगा।

  • UNIX के तहत, फ़ाइल बनाई जाती है world readableऔर MySQL सर्वर के स्वामित्व में है। इसका मतलब यह है कि यद्यपि आप फ़ाइल को पढ़ पाएंगे, आप इसे हटाने में सक्षम नहीं होंगे।

कच्चे डेटा के रूप में निर्यात तालिकाएँ

mysqldumpप्रोग्राम का उपयोग तालिकाओं और डेटाबेस को कॉपी या बैक करने के लिए किया जाता है। यह टेबल आउटपुट को या तो एक के रूप में लिख सकता हैRaw Datafile या के एक सेट के रूप में INSERT बयान जो तालिका में रिकॉर्डों को फिर से बनाते हैं।

किसी तालिका को डेटाफ़ाइल के रूप में डंप करने के लिए, आपको एक निर्दिष्ट करना होगा --tab विकल्प जो निर्देशिका को इंगित करता है, जहां आप फ़ाइल लिखना MySQL सर्वर चाहते हैं।

उदाहरण के लिए, डंप करने के लिए tutorials_tbl से तालिका TUTORIALS में एक फ़ाइल के लिए डेटाबेस /tmp निर्देशिका, नीचे दिखाए गए अनुसार एक कमांड का उपयोग करें।

$ mysqldump -u root -p --no-create-info \
   --tab=/tmp tutorials tutorials_tbl
password ******

SQL प्रारूप में तालिका सामग्री या परिभाषाएँ निर्यात करना

किसी फ़ाइल में SQL प्रारूप में एक तालिका निर्यात करने के लिए, नीचे दिखाए गए आदेश का उपयोग करें।

$ mysqldump -u root -p TUTORIALS tutorials_tbl > dump.txt
password ******

यह एक फाइल बना देगा जिसमें नीचे दी गई सामग्री होगी।

-- MySQL dump 8.23
--
-- Host: localhost    Database: TUTORIALS
---------------------------------------------------------
-- Server version       3.23.58

--
-- Table structure for table `tutorials_tbl`
--

CREATE TABLE tutorials_tbl (
   tutorial_id int(11) NOT NULL auto_increment,
   tutorial_title varchar(100) NOT NULL default '',
   tutorial_author varchar(40) NOT NULL default '',
   submission_date date default NULL,
   PRIMARY KEY  (tutorial_id),
   UNIQUE KEY AUTHOR_INDEX (tutorial_author)
) TYPE = MyISAM;

--
-- Dumping data for table `tutorials_tbl`
--

INSERT INTO tutorials_tbl 
   VALUES (1,'Learn PHP','John Poul','2007-05-24');
INSERT INTO tutorials_tbl 
   VALUES (2,'Learn MySQL','Abdul S','2007-05-24');
INSERT INTO tutorials_tbl 
   VALUES (3,'JAVA Tutorial','Sanjay','2007-05-06');

कई तालिकाओं को डंप करने के लिए, उन सभी को डेटाबेस नाम तर्क के बाद नाम दें। एक संपूर्ण डेटाबेस को डंप करने के लिए, डेटाबेस के बाद किसी भी तालिकाओं का नाम न दें जैसा कि निम्नलिखित कोड ब्लॉक में दिखाया गया है।

$ mysqldump -u root -p TUTORIALS > database_dump.txt
password ******

अपने होस्ट पर उपलब्ध सभी डेटाबेस का बैकअप लेने के लिए, निम्न कोड का उपयोग करें।

$ mysqldump -u root -p --all-databases > database_dump.txt
password ******

--All- डेटाबेस विकल्प MySQL 3.23.12 संस्करण में उपलब्ध है। इस पद्धति का उपयोग डेटाबेस बैकअप रणनीति को लागू करने के लिए किया जा सकता है।

किसी अन्य होस्ट को टेबल्स या डेटाबेस कॉपी करना

यदि आप एक MySQL सर्वर से दूसरे में टेबल या डेटाबेस को कॉपी करना चाहते हैं, तो उपयोग करें mysqldump डेटाबेस नाम और तालिका नाम के साथ।

स्रोत होस्ट पर निम्न आदेश चलाएँ। यह पूरा डेटाबेस डंप करेगाdump.txt फ़ाइल।

$ mysqldump -u root -p database_name table_name > dump.txt
password *****

जैसा कि ऊपर बताया गया है, आप किसी विशेष तालिका नाम का उपयोग किए बिना पूरा डेटाबेस कॉपी कर सकते हैं।

अब, दूसरे होस्ट पर ftp dip.txt फ़ाइल और निम्न कमांड का उपयोग करें। इस आदेश को चलाने से पहले, सुनिश्चित करें कि आपने गंतव्य सर्वर पर डेटाबेस_नाम बनाया है।

$ mysql -u root -p database_name < dump.txt
password *****

एक मध्यस्थ फ़ाइल का उपयोग किए बिना इसे पूरा करने का एक और तरीका यह है कि mysqldump के आउटपुट को नेटवर्क पर सीधे दूरस्थ SQL सर्वर पर भेजा जाए। यदि आप होस्ट से दोनों सर्वर से कनेक्ट कर सकते हैं जहां स्रोत डेटाबेस रहता है, तो निम्न कमांड का उपयोग करें (सुनिश्चित करें कि आपके पास दोनों सर्वरों पर पहुंच है)।

$ mysqldump -u root -p database_name \
   | mysql -h other-host.com database_name

Mysqldump में, कमांड का आधा हिस्सा लोकल सर्वर से कनेक्ट होता है और पाइप में डंप आउटपुट को लिखता है। कमांड का शेष आधा अन्य-host.com पर दूरस्थ MySQL सर्वर से जुड़ता है। यह इनपुट के लिए पाइप को पढ़ता है और प्रत्येक स्टेटमेंट को दूसरे-host.com सर्वर पर भेजता है।