這篇文章給大家介紹Mysql中有哪些導(dǎo)出數(shù)據(jù)的方式,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
目前創(chuàng)新互聯(lián)已為1000+的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁(yè)空間、網(wǎng)站托管、服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計(jì)、秀山土家族苗族網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。具體語(yǔ)法如下:
【select 語(yǔ)句】 into outfile 【導(dǎo)出文件名】 【導(dǎo)出參數(shù)】
【select語(yǔ)句】是經(jīng)典的查詢SQL,可以指定列、可以有where條件、group、order、limit等。
【導(dǎo)出文件名】是目標(biāo)文件的完整路徑。由于mysql賬戶的權(quán)限問(wèn)題,通常我們會(huì)將文件導(dǎo)出到臨時(shí)目錄,如/tmp/mysql/user/201810.csv
【導(dǎo)出參數(shù)】
fields terminated by 'str':設(shè)置字段之間的分隔符,默認(rèn)值是"\t"。
fields enclosed by 'char':設(shè)置包括住字段的值的符號(hào),如單引號(hào)、雙引號(hào)等,默認(rèn)情況下不使用任何符號(hào)。
fields optionally enclosed by 'char':設(shè)置括住CHAR、VARCHAR和TEXT等字符型字段的分隔符,默認(rèn)情況下不使用任何符號(hào)。
fields escaped by 'char':設(shè)置轉(zhuǎn)義字符,默認(rèn)值為"\"。
lines starting by 'str':設(shè)置每行數(shù)據(jù)開(kāi)頭的字符,可以為單個(gè)或多個(gè)字符。默認(rèn)情況下不使用任何字符。
lines terminated by 'char':設(shè)置每行數(shù)據(jù)結(jié)尾的字符,可以為單個(gè)或多個(gè)字符。默認(rèn)值是"\n"。
譬如:
select * from platform_user into outfile '/tmp/mysql/user/201810.csv' fields terminated by ',' enclosed by '"' lines starting by '\r' terminated by '\n';
如果導(dǎo)出的數(shù)據(jù),涉及到中文,打開(kāi)csv可能會(huì)看到亂碼。處理亂碼,首先要確保數(shù)據(jù)庫(kù)支持中文(通常設(shè)置UTF8編碼即可)
vim /etc/my.cnf, 添加如下幾個(gè)選項(xiàng):
[client] default-character-set=utf8 [mysqld] character_set_server=utf8 [mysql] default-character-set=utf8
即便數(shù)據(jù)庫(kù)已經(jīng)是utf8,導(dǎo)出的文件download本地依然可能有亂碼,在服務(wù)器上less,tail看到的結(jié)果都是正常的?
在本地環(huán)境(windows)用記事本打開(kāi)csv,另存編碼格式ANSI即可,這是由于excel的編碼格式?jīng)Q定的。
Part2 mysqldump導(dǎo)出數(shù)據(jù)
作為開(kāi)發(fā)人員或者運(yùn)維人員,mysqldump使用的頻率更高,因?yàn)樗茏龅氖虑楦?。mysqldump屬于邏輯備份工具,因?yàn)樗鼘?dǎo)出的是結(jié)果,多以SQL的形式展示,并不記錄數(shù)據(jù)的變化過(guò)程。關(guān)于物理備份,可以參照一本名為“MySQL技術(shù)內(nèi)幕”的書(shū)籍,其中有詳細(xì)的描述。
mysqldump的語(yǔ)法很簡(jiǎn)單,即
mysqldump 【options】> dump.sql
但是options的可選參數(shù)卻很多,手冊(cè)上將他分了幾大類(lèi),鏈接option、文件option、數(shù)據(jù)定義DDL option、Debug option、國(guó)際化option、集群Replication option、格式 option、性能option、事務(wù)option等。感興趣的同學(xué)可以參照MYSQL官方手冊(cè)的定義,這里僅介紹幾種常見(jiàn)的應(yīng)用場(chǎng)景。
關(guān)于Mysql中有哪些導(dǎo)出數(shù)據(jù)的方式就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。