中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現MySQL表數據的導入導出

發布時間:2020-08-01 10:52:00 來源:億速云 閱讀:213 作者:小豬 欄目:MySQL數據庫

這篇文章主要講解了如何實現MySQL表數據的導入導出,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

數據導出

1.  使用 SELECT ...INTO OUTFILE ...命令來導出數據,具體語法如下。

mysql> SELECT * FROM tablename INTO OUTFILE 'target_file' [option];

其中 option 參數可以是以下選項:

FIELDS TEMINATED BY 'string' (字符分斷符)

FIELDS [OPTIONALLY] ENCLOSED BY 'CHAR' (字段引用符,如果加OPTIONAL選項則只用在char、varchar 和 text 等字符型字段上。默認不使用引用符)

FIELDS EXCAPED BY 'CAHR' (轉移字符,默認為'\')

LINES STARTING BY 'string' (每行前都加此字符串,默認'')

LINES TERMINATED BY 'string' (行結束符,默認為'\n')

其中char表示此符號只能是單個字符,string 表示可以是字符串。

Example: 導出test表的所有數據 mysql> select * from test into outfile '/path/files.txt'

2. 用mysqldump 導出數據為文本

mysqldump -u username -T target_dir dbname tablename [option]

其中option 參數可以是以下選項:
--fields-terminated-by=name(字段分隔符);
--fields-enclosed-by=name(字段引用符);
--fields-optionally-enclosed-by=name(字段引用符,只用在 char、varchar 和 text 等字符 型字段上);
--fields-escaped-by=name(轉義字符);
--lines-terminated-by=name(記錄結束符)。

Example: 導出test數據庫中的custom表的所有數據   mysqldump -uroot -T /tmp test custom

除了生成數據文件 custom.txt 之外,還生成一個 custom.sql 文件,里面記錄了 custom 表的創建腳本。

數據導入

只討論用 SELECT... INTO OUTFILE 或者 mysqldump 導出的純數據文本的導入方法。

1. 使用"LOAD DATA INFILE..."

mysql > LOAD DATA [LOCAL] INFILE 'filename' into TABLE tablename [option]

option 可以是以下選項:
¡ FIELDS TERMINATED BY 'string'(字段分隔符,默認為制表符'\t');
¡ FIELDS [OPTIONALLY] ENCLOSED BY 'char'(字段引用符,如果加 OPTIONALLY 選項則只用 在 char、varchar 和 text 等字符型字段上。默認不使用引用符);
ESCAPED BY 'char'(轉義字符,默認為'\'); STARTING BY 'string'(每行前都加此字符串,默認''); TERMINATED BY 'string'(行結束符,默認為'\n');
¡ FIELDS
¡ LINES
¡ LINES
¡ IGNORE number LINES(忽略輸入文件中的前 n 行數據);
¡ (col_name_or_user_var,...) (按照列出的字段順序和字段數量加載數據); ¡ SET col_name = expr,... 將列做一定的數值轉換后再加載。
其中 char 表示此符號只能是單個字符,string 表示可以是字符串。
FILELD 和 LINES 和前面 SELECT ...INTO OUTFILE...的含義完全相同,不同的是多了幾個不同的選 項,下面的例子將文件“/tmp/emp.txt”中的數據加載到表 emp 中:

mysql > load data infile '/tmp/emp.txt' into table emp

如果不希望加載文件中的前兩行,可以如下操作:

mysql> load data infile '/tmp/emp.txt' into table emp fields ignore 2 lines;

指定導入的列:

mysql > load data infile '/tmp/emp.txt' into table emp ignore 2 lines (id,content,name);

2. 用mysqlimport 來實現,具體命令如下:

shell > mysqlimport -u root -p*** [--LOCAL] dbname order_tab.txt [option]

Example: 導入數據到order表   shell > mysqlimport -uroot test /tmp/emp.txt 

注意:如果導入和導出是跨平臺操作的(Windows 和 Linux),那么要注意設置參數 line-terminated-by , Windows 上 設 置 為 line-terminated-by='\r\n' , Linux 上 設 置 為 line-terminated-by='\n'。

清空表數據

delete from 表名;

truncate table 表名;

不帶where參數的delete語句可以刪除mysql表中所有內容,使用truncate table也可以清空mysql表中所有內容。

效率上truncate比delete快,但truncate刪除后不記錄mysql日志,不可以恢復數據。

delete的效果有點像將mysql表中所有記錄一條一條刪除到刪完,

而truncate相當于保留mysql表的結構,重新創建了這個表,所有的狀態都相當于新表。

看完上述內容,是不是對如何實現MySQL表數據的導入導出有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

佛教| 永泰县| 汕尾市| 松江区| 武鸣县| 南靖县| 克东县| 万载县| 万荣县| 镇巴县| 寻乌县| 民丰县| 台山市| 灵石县| 会泽县| 博野县| 饶河县| 平昌县| 永清县| 济源市| 奉节县| 荆州市| 盱眙县| 塔河县| 天津市| 正宁县| 奎屯市| 泽库县| 舒城县| 武安市| 金堂县| 项城市| 梧州市| 新田县| 肇州县| 稻城县| 屏南县| 道孚县| 图木舒克市| 荥经县| 东乡|