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

时间:2023年10月04日

/

来源:网络

/

编辑:佚名

要使用PHP PDO连接数据库,然后清空数据库并导入.sql文件,您可以按照以下步骤操作:
使用PDO连接到数据库:
$dbHost = "您的主机名";
$dbName = "您的数据库名";
$dbUser = "您的用户名";
$dbPass = "您的密码";
$dbCharset = "utf8mb4";
$dsn = "mysql:host=$dbHost;dbname=$dbName;charset=$dbCharset";
$pdo = new PDO($dsn, $dbUser, $dbPass);
清空数据库表:
$tables = $pdo->query("SHOW TABLES")->fetchAll(PDO::FETCH_COLUMN);
foreach ($tables as $table) {
    $pdo->exec("TRUNCATE TABLE $table");
}
导入.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文件的路径)。
请注意,此函数假定您已经备份了数据库,因为它将永久删除所有表数据。请谨慎使用此函数。
猜你需要

豫ICP备2021026617号-1  豫公网安备:41172602000185   Copyright © 2021-2028 www.78moban.com/ All Rights Reserved

本站作品均来自互联网,转载目的在于传递更多信息,并不代表本站赞同其观点和对其真实性负责。如有侵犯您的版权,请联系 1565229909#qq.com(把#改成@),我们将立即处理。