要使用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文件的路径)。
请注意,此函数假定您已经备份了数据库,因为它将永久删除所有表数据。请谨慎使用此函数。