>데이터 베이스 >MySQL 튜토리얼 >파일을 성공적으로 저장했는데도 Node.js를 사용하여 MySQL 데이터베이스 덤프가 빈 파일로 나타나는 이유는 무엇입니까?

파일을 성공적으로 저장했는데도 Node.js를 사용하여 MySQL 데이터베이스 덤프가 빈 파일로 나타나는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-04 03:41:02873검색

Why is my MySQL database dump using Node.js resulting in an empty file despite successful file saving?

Node.js를 사용하여 MySQL 데이터베이스 덤프

문제

MySQL 데이터베이스를 덤프하기 위해 cron 스크립트를 생성하려고 시도했지만 빈 파일이 생성되었습니다. 파일 저장 성공. 로그 인쇄에서도 빈 문자열이 생성됩니다.

원인

이 문제는 제공된 코드의 여러 문제로 인해 발생합니다.

  1. connection.connect를 통한 초기 데이터베이스 연결 부족 ()
  2. connection.connect() 콜백 외부에 콜백 코드가 배치되어 실행 방지
  3. SQL 호출이 완료되기 전에 연결이 조기 종료
  4. 백업 파일을 잘못된 콜백(데이터 채우기 전)

해결 방법

다음 코드는 이러한 문제를 수정하고 작동하는 솔루션을 제공합니다.

var mysql_backup = function() {
    this.backup = '';
    this.mysql = require('mysql');

    this.init = function() {
        this.connection = this.mysql.createConnection({
            user: 'root',
            password: 'root',
            database: 'test'
        });

        // Connect to the database
        this.connection.connect(function(err) {
            if (err) console.log(err);
            db.get_tables(function() {});
        });
    };

    this.query = function(sql, callback) {
        this.connection.query(sql, function (error, results, fields) {
            if (error) {
                throw error;
            }
            if (results.length  > 0) {
                callback(results);
            }
        });
    };

    this.get_tables = function(callback){
        var counter = 0;
        var me = this;
        this.query('SHOW TABLES', function(tables) {
            for (table in tables) {
                counter++;
                me.query('SHOW CREATE TABLE ' + tables[table].Tables_in_test, function(r){
                    for (t in r) {
                        me.backup += "DROP TABLE " + r[t].Table + "\n\n";
                        me.backup += r[t]["Create Table"] + "\n\n";
                    }
                    counter--;
                    if (counter === 0) {
                        me.save_backup();
                        me.connection.destroy();
                    }
                });
            }
        });
    };

    this.save_backup = function() {
        var fs = require('fs');
        fs.writeFile("./backup_test.txt", this.backup, function(err) {
            if(err) {
                console.log(err);
            } else {
                console.log("The file was saved!");
            }
        });
    }

};

var db = new mysql_backup;
db.init();

추가 참고 사항

다음을 사용하는 것을 고려하세요:

  • 명확성을 위해 me 대신 self
  • 구문에서 for ...에 대한 숫자 for 루프
  • 일관된 콜백 형식(err, stuff)
  • 오류 처리 및 콜백 중첩 관리 개선을 약속합니다

위 내용은 파일을 성공적으로 저장했는데도 Node.js를 사용하여 MySQL 데이터베이스 덤프가 빈 파일로 나타나는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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