詳解Mysql導(dǎo)出數(shù)據(jù)的幾種方式
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ù)】
- 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ù)開頭的字符,可以為單個(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ù),涉及到中文,打開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)樗茏龅氖虑楦?。mysqldump屬于邏輯備份工具,因?yàn)樗鼘?dǎo)出的是結(jié)果,多以SQL的形式展示,并不記錄數(shù)據(jù)的變化過程。關(guān)于物理備份,可以參照一本名為“MySQL技術(shù)內(nèi)幕”的書籍,其中有詳細(xì)的描述。
mysqldump的語法很簡(jiǎn)單,即
mysqldump 【options】> dump.sql
但是options的可選參數(shù)卻很多,手冊(cè)上將他分了幾大類,鏈接option、文件option、數(shù)據(jù)定義DDL option、Debug option、國(guó)際化option、集群Replication option、格式 option、性能option、事務(wù)option等。感興趣的同學(xué)可以參照MYSQL官方手冊(cè)的定義,這里僅介紹幾種常見的應(yīng)用場(chǎng)景。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- MySQL數(shù)據(jù)庫導(dǎo)入導(dǎo)出數(shù)據(jù)之報(bào)錯(cuò)解答實(shí)例講解
- mysql實(shí)現(xiàn)從導(dǎo)出數(shù)據(jù)的sql文件中只導(dǎo)入指定的一個(gè)表
- MySQL導(dǎo)出數(shù)據(jù)遇到secure-file-priv問題的解決方法
- MySQL數(shù)據(jù)庫使用mysqldump導(dǎo)出數(shù)據(jù)詳解
- MySQL 導(dǎo)出數(shù)據(jù)為csv格式的方法
- mysqldump命令導(dǎo)入導(dǎo)出數(shù)據(jù)庫方法與實(shí)例匯總
- MYSQL命令行導(dǎo)入導(dǎo)出數(shù)據(jù)庫詳解
- mysql 導(dǎo)入導(dǎo)出數(shù)據(jù)庫、數(shù)據(jù)表的方法
- 淺析Mysql 中如何導(dǎo)出數(shù)據(jù)
相關(guān)文章
如何實(shí)現(xiàn)mysql的遠(yuǎn)程連接
這篇文章詳細(xì)介紹了mysql如何實(shí)現(xiàn)遠(yuǎn)程連接,文中有詳細(xì)的代碼實(shí)例講解,有一定的參考價(jià)值,需要的朋友可以參考閱讀2023-04-04在linux中導(dǎo)入sql文件的方法分享(使用命令行轉(zhuǎn)移mysql數(shù)據(jù)庫)
為使用阿里云主機(jī),沒有裝ftp,也沒有裝phpmyadmin,所以一切都得靠命令行。轉(zhuǎn)移網(wǎng)站的重要一步就是轉(zhuǎn)移數(shù)據(jù)庫,這里簡(jiǎn)單介紹一下如何在這種情況下導(dǎo)入sql文件2014-02-02mysql建表報(bào)錯(cuò):invalid?default?value?for?'date'的解決方
最近遇到一個(gè)這樣的問題,出現(xiàn)了invalid default value for 'end_date'錯(cuò)誤,所以下面這篇文章主要給大家介紹了關(guān)于mysql建表報(bào)錯(cuò):invalid?default?value?for?'date'的解決方法,需要的朋友可以參考下2022-12-12MySQL8.0實(shí)現(xiàn)窗口函數(shù)計(jì)算同比環(huán)比
本文主要介紹了MySQL8.0實(shí)現(xiàn)窗口函數(shù)計(jì)算同比環(huán)比,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06MySQL5.73?root用戶密碼修改方法及ERROR?1193、ERROR1819與ERROR1290報(bào)錯(cuò)解決
這篇文章主要給大家介紹了關(guān)于MySQL5.73?root用戶密碼修改方法及ERROR?1193、ERROR1819與ERROR1290:...?running?with?--skip-...報(bào)錯(cuò)的解決方法,文中通過圖文將解決的步驟介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02區(qū)別于Oracle的MySQL?insert會(huì)阻塞update
這篇文章主要介紹了區(qū)別于Oracle的MySQL?insert會(huì)阻塞update的問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03mysql 5.7.21 安裝配置方法圖文教程(window)
這篇文章主要為大家詳細(xì)介紹了window環(huán)境下mysql5.7.21安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02MySQL修改安全策略時(shí)報(bào)錯(cuò):ERROR?1193?(HY000)的解決辦法
這篇文章主要給大家介紹了關(guān)于MySQL修改安全策略時(shí)報(bào)錯(cuò):ERROR?1193?(HY000):?Unknown?system?variable?‘validate_password_policy‘的解決方法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02