程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL 文本文件的導入導出數據sql演示

MySQL 文本文件的導入導出數據sql演示

編輯:MySQL綜合教程

導入導出數據在mysql中我們多半會使用mysqldump命令了,今天我要介紹是其它命令導入導出文本文件命令,希望能給您帶來幫助。

MySQL寫入數據通常用insert語句,如
 
INSERT INTO person VALUES(張三,20),(李四,21),(王五,70)…;

但有時為了更快速地插入大批量數據或交換數據,需要從文本中導入數據或導出數據到文本。
一、 建立測試表,准備數據

首先建立一個用於測試的表示學生信息的表,字段有id、姓名、年齡、城市、薪水。Id和姓名不
能為空。
 

 代碼如下 復制代碼 CREATE TABLE person(
    id INT NOT NULL AUTO_INCREMENT,
    name VARCHAR(40) NOT NULL,
    city VARCHAR(20),
    salary INT,
    PRIMARY KEY(id)
)engine=innodb charset=gb2312;

創建表截圖如下:

1

接著寫一個用於導入的文本文件:c:data.txt。

張三    31    北京    3000
李四    25    杭州    4000
王五    45    N     4500
小明    29    天津    N

3

每一項之間用Tab鍵進行分隔,如果該字段為NULL,則用N表示。

二、 導入數據

輸入命令,進行導入。

 代碼如下 復制代碼

LOAD DATA LOCAL INFILE "c:/data.txt"
INTO TABLE person(name,age,city,salary);

導入數據截圖如下:

2

其中local表示本地。執行後,可以看到NULL數據也被正確地導入。

三、 導出數據

現在將這個表導出為文本文件:c:data_out.txt。

 代碼如下 復制代碼

 
SELECT name,age,city,salary
INTO OUTFILE "c:/data_out.txt"
LINES TERMINATED BY "rn"
FROM person;

導出數據截圖如下:

4

其中lines terminated by “rn”表示每一行(即每一條記錄)用rn分隔,rn是window系
統的換行符。導出的data_out.txt與data.txt的內容完全一樣。


當然我們還可以使用mysqldump命令導入導出了,這個才是標准的mysql 數據導入導出命令了。

第一步,導出舊庫

 代碼如下 復制代碼

mysqldump --default-character-set latin1 -uroot -pXXX --database db > /tmp/old.sql

第二步,轉換編碼

 代碼如下 復制代碼

iconv -t utf-8 -f gbk -c /tmp/old.sql > /tmp/new.sql

第三步,導入新庫

修改new.sql,增加一條sql語句: “SET NAMES utf8;”,保存。

四、 運行環境

Windows vista home basic
MySQL 5.1.34-community

五、 注意

字段之間的分隔和記錄(行)之間的分隔默認是t(即Tab)和n。但可以改變,如:
FIELDS TERMINATED BY ‘,’ –字段用,進行分隔
LINES TERMINATED BY ‘;’ –記錄用; 進行分隔
另外要注意其它操作系統的換行符與windows可能不相同。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved