久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL 表數(shù)據(jù)的導(dǎo)入導(dǎo)出操作示例

瀏覽:2日期:2023-10-15 12:57:17

本文實例講述了MySQL 表數(shù)據(jù)的導(dǎo)入導(dǎo)出操作。分享給大家供大家參考,具體如下:

數(shù)據(jù)導(dǎo)出

1. 使用 SELECT ...INTO OUTFILE ...命令來導(dǎo)出數(shù)據(jù),具體語法如下。

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

其中 option 參數(shù)可以是以下選項:

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

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

FIELDS EXCAPED BY ’CAHR’ (轉(zhuǎn)移字符,默認為’’)

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

LINES TERMINATED BY ’string’ (行結(jié)束符,默認為’n’)

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

Example: 導(dǎo)出test表的所有數(shù)據(jù) mysql> select * from test into outfile ’/path/files.txt’

2. 用mysqldump 導(dǎo)出數(shù)據(jù)為文本

mysqldump -u username -T target_dir dbname tablename [option]其中option 參數(shù)可以是以下選項:--fields-terminated-by=name(字段分隔符);--fields-enclosed-by=name(字段引用符);--fields-optionally-enclosed-by=name(字段引用符,只用在 char、varchar 和 text 等字符 型字段上);--fields-escaped-by=name(轉(zhuǎn)義字符);--lines-terminated-by=name(記錄結(jié)束符)。Example: 導(dǎo)出test數(shù)據(jù)庫中的custom表的所有數(shù)據(jù) mysqldump -uroot -T /tmp test custom

除了生成數(shù)據(jù)文件 custom.txt 之外,還生成一個 custom.sql 文件,里面記錄了 custom 表的創(chuàng)建腳本。

數(shù)據(jù)導(dǎo)入

只討論用 SELECT... INTO OUTFILE 或者 mysqldump 導(dǎo)出的純數(shù)據(jù)文本的導(dǎo)入方法。

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’(轉(zhuǎn)義字符,默認為’’); STARTING BY ’string’(每行前都加此字符串,默認’’); TERMINATED BY ’string’(行結(jié)束符,默認為’n’);¡ FIELDS¡ LINES¡ LINES¡ IGNORE number LINES(忽略輸入文件中的前 n 行數(shù)據(jù));¡ (col_name_or_user_var,...) (按照列出的字段順序和字段數(shù)量加載數(shù)據(jù)); ¡ SET col_name = expr,... 將列做一定的數(shù)值轉(zhuǎn)換后再加載。其中 char 表示此符號只能是單個字符,string 表示可以是字符串。FILELD 和 LINES 和前面 SELECT ...INTO OUTFILE...的含義完全相同,不同的是多了幾個不同的選 項,下面的例子將文件“/tmp/emp.txt”中的數(shù)據(jù)加載到表 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;指定導(dǎo)入的列:mysql > load data infile ’/tmp/emp.txt’ into table emp ignore 2 lines (id,content,name);

2. 用mysqlimport 來實現(xiàn),具體命令如下:

shell > mysqlimport -u root -p*** [--LOCAL] dbname order_tab.txt [option]Example: 導(dǎo)入數(shù)據(jù)到order表 shell > mysqlimport -uroot test /tmp/emp.txt

注意:如果導(dǎo)入和導(dǎo)出是跨平臺操作的(Windows 和 Linux),那么要注意設(shè)置參數(shù) line-terminated-by , Windows 上 設(shè) 置 為 line-terminated-by=’rn’ , Linux 上 設(shè) 置 為 line-terminated-by=’n’。

清空表數(shù)據(jù)

delete from 表名;

truncate table 表名;

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

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

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

而truncate相當于保留mysql表的結(jié)構(gòu),重新創(chuàng)建了這個表,所有的狀態(tài)都相當于新表。

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總》

希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。

相關(guān)文章:
主站蜘蛛池模板: 张北县| 三门县| 德兴市| 磴口县| 白城市| 乐业县| 福建省| 喀喇沁旗| 台州市| 沭阳县| 金湖县| 鸡泽县| 河北省| 西昌市| 全州县| 石屏县| 阳谷县| 南城县| 交城县| 三都| 巴塘县| 临沂市| 广平县| 荣成市| 湟源县| 上蔡县| 灯塔市| 泰和县| 永寿县| 奈曼旗| 宝清县| 利津县| 湘西| 安图县| 满城县| 河北省| 会泽县| 叙永县| 武城县| 车险| 吴忠市|