>  기사  >  데이터 베이스  >  더 쉬운 서버 업로드를 위해 Mysqldump 출력을 더 작은 파일로 분할하는 방법은 무엇입니까?

더 쉬운 서버 업로드를 위해 Mysqldump 출력을 더 작은 파일로 분할하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-17 03:06:03995검색

How to Split Mysqldump Outputs into Smaller Files for Easier Server Upload?

서버 업로드를 위해 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.