首页 > 数据库 > mysql教程 > 如何使用 PHP 安全地将 .sql 文件导入 MySQL?

如何使用 PHP 安全地将 .sql 文件导入 MySQL?

Patricia Arquette
发布: 2024-12-06 21:20:13
原创
524 人浏览过

How Can I Safely Import a .sql File into MySQL Using PHP?

使用 PHP 将 .sql 文件导入 MySQL 数据库

尝试使用 PHP 将 .sql 文件导入 MySQL 数据库时,导入过程中经常会遇到错误消息,报告出现问题。此错误消息包括有关数据库名称、用户名、密码、主机名和导入文件名的详细信息。

问题中提供的代码使用 mysql_* 函数,该函数从 PHP 5.5.0 开始已弃用并在 PHP 7.0.0 中删除。相反,应该使用替代的 MySQL API,例如 mysqli 或 PDO_MySQL。

使用 MySQL 客户端的替代导入方法

将文件导入过程委托给 MySQL 客户端通常是更可靠的方法。 MySQL 提供了可以高效处理导入的命令行工具。

改进了导入 .sql 文件的 PHP 代码

提供了使用更合适的导入方法的替代 PHP 代码下面:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

<?php

 

// File name

$filename = 'churc.sql';

// MySQL host

$mysql_host = 'localhost';

// MySQL username

$mysql_username = 'root';

// MySQL password

$mysql_password = '';

// Database name

$mysql_database = 'dump';

 

// Establish MySQL connection

$mysqli = new mysqli($mysql_host, $mysql_username, $mysql_password, $mysql_database);

if ($mysqli->connect_error) {

    echo 'Error connecting to MySQL: ' . $mysqli->connect_error;

    exit;

}

 

// Read entire file

$lines = file($filename);

 

// Process each line

foreach ($lines as $line) {

    // Skip comments and empty lines

    if (substr($line, 0, 2) == '--' || $line == '') {

        continue;

    }

 

    // Execute query

    if ($mysqli->query($line)) {

        echo 'Query successfully executed: ' . $line . '<br>';

    } else {

        echo 'Error executing query: ' . $line . '<br>';

    }

}

echo 'Tables imported successfully';

$mysqli->close();

 

?>

登录后复制

此改进的代码利用 mysqli 扩展连接到 MySQL 并执行 .sql 文件行中的查询按线路。

以上是如何使用 PHP 安全地将 .sql 文件导入 MySQL?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板