!!...MySQL&MariaDB

[MySQL] MySQL 백업 mysqldump 사용법 정리

qnfmfmd_ 2015. 3. 4. 14:04
BIG

 

- 원격지에서 데이타 백업 

shell> mysqldump -h000.000.000.000 -u[USERID] -p[PASSWORD] [TARGET DB NAME] [TARGET TABLE NAME] > ./test.sql 

 

- DB 와 테이블을 지정하여 백업 

shell> mysqldump [options] db_name [tbl_name] > filename 

 

- 전체 데이터베이스 풀 백업 

shell> mysqldump [options] --all-database

--all-database 대신 -A 옵션을 지정해도 된다. 

 

-테이블 스키마 제외 데이타만 백업 

shell> mysqldump -t -h000.000.000.000 -u[USERID] -p[PASSWORD] [TARGET DB NAME] [TARGET TABLE NAME] > ./test.sql 

 

- 테이블 스키마 백업 ( 데이타 제외 )

shell> mysqldump -u[USERID] -p[PASSWORD] --no-data dbname > schema.sql

 

- CSV 형식으로 백업 

mysqldump -u root -p[ 패스워드 ] [DB명] [Table명] 

--tab=[파일저장경로] 

--fields-terminated-by=',' 

--lines-terminated-by='\r\n'  --no-create-info --no-create-db --no-create-info 

 

 

 

 

===============================================================================

 

 

 

 

몇가지 옵션들

--disable-keys, -K

MyISAM 테이블에 덤프파일을 통해 INSERT 시 사용하면 덤프파일을 읽어와서

INSERT 시 처리속도를 높일 수 있다.

모든 행이 INSERT 된 후에 인덱스를 생성해주는 옵션이다.

 

--extend-insert, -e

INSERT 문을 생성 시 다중 INSERT 문으로 생성해주는 옵션이다.

동일한 열 지정이 제외되므로 그만큼 파일 사이즈가 줄어들고 복원 시

삽입속도를 좀 더 빠르게 할 수 있다.

 

--quick, -q

이 옵션은 테이블에 대한 열을 서버에서 한 번에 한 열씩 추출하여 메모리에 버퍼링 된 데이터를

덤프하므로 대용량 테이블을 덤프할 때 유용하다.

 

--routines, -R

스토어드 프로시저, 함수를 덤프한다. 덤프된 루틴이 재생성될 때 원래의 타임스태프 값을

가지게 하기 위해서는 mysql.proc 테이블의 내용물을 직접 덤프하여 사용한다.

 

--where='where_condition, -w 'where_condition'

주어진 where 조건문에 해당되는 데이터만 덤프한다. 조건 지정 시 인용부호를 사용한다.

ex) -where="userid='홍길동'"

     -w "depth >1"

LIST