집 >데이터 베이스 >MySQL 튜토리얼 >더 쉬운 서버 업로드를 위해 Mysqldump 출력을 더 작은 파일로 분할하는 방법은 무엇입니까?
한 MySQL 데이터베이스에서 다른 MySQL 데이터베이스로 테이블 데이터를 이동하려고 하면 파일 크기 제한이 발생할 수 있습니다. mysqldump의 출력이 업로드에 허용된 크기를 초과하는 경우 출력을 더 작은 파일로 분할하는 방법이 필요합니다.
한 가지 해결 방법은 mysqldump와 함께 --extended-insert=FALSE 옵션을 사용하는 것입니다. 그러면 적절한 --lines 옵션과 함께 Split(1)을 사용하여 분할할 수 있는 .sql 파일이 생성됩니다. 그러나 원격 서버에서 cat(1)을 사용할 수 없는 경우 이 방법은 실행 불가능합니다.
또는 bash 스크립트를 사용하여 덤프 파일을 각 테이블에 대한 별도의 파일로 분할할 수 있습니다. 스크립트는 csplit을 사용하여 테이블 구조나 테이블 이름과 같은 특정 패턴을 기반으로 파일을 나눕니다.
다음은 예제 스크립트입니다.
#!/bin/bash START="/-- Table structure for table/" if [ $# -lt 1 ] || [[ == "--help" ]] || [[ == "-h" ]]; then echo "USAGE: extract all tables:" echo " DUMP_FILE" echo "extract one table:" echo " DUMP_FILE [TABLE]" exit fi if [ $# -ge 2 ]; then # extract one table csplit -s -ftable "/-- Table structure for table/" "%-- Table structure for table \`\`%" "/-- Table structure for table/" "%40103 SET TIME_ZONE=@OLD_TIME_ZONE%1" else # extract all tables csplit -s -ftable "$START" {*} fi [ $? -eq 0 ] || exit mv table00 head FILE=`ls -1 table* | tail -n 1` if [ $# -ge 2 ]; then # cut off all other tables mv $FILE foot else # cut off the end of each file csplit -b '%d' -s -f$FILE $FILE "/40103 SET TIME_ZONE=@OLD_TIME_ZONE/" {*} mv ${FILE}1 foot fi for FILE in `ls -1 table*`; do NAME=`head -n1 $FILE | cut -d$'\x60' -f2` cat head $FILE foot > "$NAME.sql" done rm head foot table*
이 스크립트는 입력 덤프 파일에 다음이 포함되어 있다고 가정합니다. 테이블 구조와 데이터. 테이블 경계에서 파일을 분할하고 각 테이블의 데이터를 적절한 파일 이름을 가진 별도의 파일에 할당합니다.
위 내용은 더 쉬운 서버 업로드를 위해 Mysqldump 출력을 더 작은 파일로 분할하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!