PHP PDO链接数据库,清空数据库,再导入.sql文件

要使用PHP PDO连接数据库,然后清空数据库并导入.sql文件,您可以按照以下步骤操作:

  1. 使用PDO连接到数据库:
    $dbHost = "您的主机名";
    $dbName = "您的数据库名";
    $dbUser = "您的用户名";
    $dbPass = "您的密码";
    $dbCharset = "utf8mb4";
    
    $dsn = "mysql:host=$dbHost;dbname=$dbName;charset=$dbCharset";
    
    $pdo = new PDO($dsn, $dbUser, $dbPass);
  2. 清空数据库表:
    $tables = $pdo->query("SHOW TABLES")->fetchAll(PDO::FETCH_COLUMN);
    
    foreach ($tables as $table) {
        $pdo->exec("TRUNCATE TABLE $table");
    }
  3. 导入.sql文件:
    $sqlFile = "路径/到/您的/sql/文件.sql";
    
    $sql = file_get_contents($sqlFile);
    
    $pdo->exec($sql);

这些步骤将连接到数据库,清空所有表,然后导入指定的.sql文件。请注意,这将永久删除所有数据,因此请确保在执行此操作之前备份您的数据库。

函数封装

好的,以下是一个包含连接到数据库,清空所有表并导入.sql文件的函数:

function clearAndImportSQL($dbHost, $dbName, $dbUser, $dbPass, $sqlFile) {
    $dbCharset = "utf8mb4";
    $dsn = "mysql:host=$dbHost;dbname=$dbName;charset=$dbCharset";

    try {
        $pdo = new PDO($dsn, $dbUser, $dbPass);
        $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        
        // 清空数据库表
        $tables = $pdo->query("SHOW TABLES")->fetchAll(PDO::FETCH_COLUMN);

        foreach ($tables as $table) {
            $pdo->exec("TRUNCATE TABLE $table");
        }

        // 导入.sql文件
        $sql = file_get_contents($sqlFile);

        $pdo->exec($sql);
        
        echo "SQL file imported successfully.";
    } catch (PDOException $e) {
        echo "Error: " . $e->getMessage();
    }

    $pdo = null;
}

该函数包含5个参数:$dbHost(数据库主机名),$dbName(数据库名称),$dbUser(数据库用户名),$dbPass(数据库密码)和$sqlFile(包含要导入的.sql文件的路径)。

请注意,此函数假定您已经备份了数据库,因为它将永久删除所有表数据。请谨慎使用此函数。

© 版权声明
THE END
喜欢就支持一下吧
点赞11
评论 抢沙发

请登录后发表评论

    暂无评论内容