MySQL導(dǎo)出數(shù)據(jù)的目的有很多種,如數(shù)據(jù)庫備份、表結(jié)構(gòu)導(dǎo)出、表數(shù)據(jù)導(dǎo)出、分析數(shù)據(jù)采取等。
Part1 select into outfile
先說最短小精悍的select into outfile, 這是小型數(shù)據(jù)庫分析數(shù)據(jù)最常用的采集數(shù)據(jù)方式,具體語法如下:
【select 語句】 into outfile 【導(dǎo)出文件名】 【導(dǎo)出參數(shù)】
【select語句】是經(jīng)典的查詢SQL,可以指定列、可以有where條件、group、order、limit等。
【導(dǎo)出文件名】是目標(biāo)文件的完整路徑。由于mysql賬戶的權(quán)限問題,通常我們會(huì)將文件導(dǎo)出到臨時(shí)目錄,如/tmp/mysql/user/201810.csv
【導(dǎo)出參數(shù)】
譬如:
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ù),涉及到中文,打開csv可能會(huì)看到亂碼。處理亂碼,首先要確保數(shù)據(jù)庫支持中文(通常設(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ù)庫已經(jīng)是utf8,導(dǎo)出的文件download本地依然可能有亂碼,在服務(wù)器上less,tail看到的結(jié)果都是正常的?
在本地環(huán)境(windows)用記事本打開csv,另存編碼格式ANSI即可,這是由于excel的編碼格式?jīng)Q定的。
Part2 mysqldump導(dǎo)出數(shù)據(jù)
作為開發(fā)人員或者運(yùn)維人員,mysqldump使用的頻率更高,因?yàn)樗茏龅氖虑楦唷ysqldump屬于邏輯備份工具,因?yàn)樗鼘?dǎo)出的是結(jié)果,多以SQL的形式展示,并不記錄數(shù)據(jù)的變化過程。關(guān)于物理備份,可以參照一本名為“MySQL技術(shù)內(nèi)幕”的書籍,其中有詳細(xì)的描述。
mysqldump的語法很簡單,即
mysqldump 【options】gt; dump.sql
但是options的可選參數(shù)卻很多,手冊上將他分了幾大類,鏈接option、文件option、數(shù)據(jù)定義DDL option、Debug option、國際化option、集群Replication option、格式 option、性能option、事務(wù)option等。感興趣的同學(xué)可以參照MYSQL官方手冊的定義,這里僅介紹幾種常見的應(yīng)用場景。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
標(biāo)簽:南充 佛山 黔南 蘭州 馬鞍山 宿遷 黃山 賀州
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Mysql導(dǎo)出數(shù)據(jù)的幾種方式》,本文關(guān)鍵詞 詳解,Mysql,導(dǎo)出,數(shù)據(jù),的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。