首先确认CSV格式和数据库表结构匹配,再通过PHP读取文件并用PDO导入MySQL。具体步骤:1. 确保CSV为UTF-8编码,字段用逗号分隔;2. 创建users表存储数据;3. 使用fgetcsv读取内容,跳过标题行,逐行插入数据库;4. 提供HTML表单上传文件。代码包含数据库连接、文件处理和SQL插入,需注意错误处理与编码设置以避免乱码。成功后提示“数据导入成功”。
PHP实现从CSV文件导入数据到MySQL是常见的需求,比如批量导入用户信息、商品数据等。整个过程主要包括:上传CSV文件、读取内容、连接数据库、插入数据。下面详细介绍具体步骤和代码示例。
1. 准备CSV文件格式
确保CSV文件的格式规范,通常第一行为字段名(可选),后续每行为一条记录,字段之间用逗号分隔。例如:
姓名,年龄,邮箱张三,25,zhangsan@example.com
李四,30,lisi@example.com
保存为 data.csv,注意编码建议使用UTF-8,避免中文乱码。
2. 创建MySQL数据表
在数据库中创建对应的表结构,例如:
立即学习“PHP免费学习笔记(深入)”;
CREATE TABLE users (id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAr(50),
age INT,
email VARCHAr(100)
);
3. 使用PHP读取并导入CSV数据
通过 fgetcsv() 函数逐行读取CSV内容,并使用PDO或mysqli将数据插入MySQL。

基于AI数字人能力,实现7*24小时AI数字人直播带货,低成本实现直播业务快速增增,全天智能在线直播


以下是完整示例代码:
zuojiankuohaophpcn?php$host = 'localhost';
$db = 'test_db';
$user = 'root';
$pass = '';
$charset = 'utf8mb4';
$dsn = "mysql:host=$host;dbname=$db;charset=$charset";
$options = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
PDO::ATTR_EMULATE_PREPARES => false,
];
try {
$pdo = new PDO($dsn, $user, $pass, $options);
} catch (PDOException $e) {
throw new PDOException($e->getMessage(), (int)$e->getCode());
}
// 检查是否上传了文件
if (isset($_FILES['csv_file']) && $_FILES['csv_file']['error'] == 0) {
$file = $_FILES['csv_file']['tmp_name'];
$handle = fopen($file, 'r');
// 跳过标题行(如果存在)
fgetcsv($handle);
while (($data = fgetcsv($handle, 1000, ',')) !== FALSE) {
$name = $data[0];
$age = $data[1];
$email = $data[2];
$stmt = $pdo->prepare("INSERT INTO users (name, age, email) VALUES (?, ?, ?)");
$stmt->execute([$name, $age, $email]);
}
fclose($handle);
echo "数据导入成功!";
} else {
echo "请上传CSV文件。";
}
?>
4. 添加HTML上传表单
提供一个简单的表单让用户上传CSV文件:
<form method="post" enctype="multipart/form-data"><input type="file" name="csv_file" accept=".csv" required>
<button type="submit">导入数据</button>
</form>
注意:必须设置 enctype="multipart/form-data" 才能上传文件。
基本上就这些。只要保证字段顺序一致、数据类型匹配、编码正确,就能顺利导入。可以在此基础上增加错误处理、重复数据检测、批量插入优化等功能。不复杂但容易忽略细节。
以上就是PHP如何实现数据导入_PHP从CSV导入mysql数据的实现步骤的详细内容,更多请关注php中文网其它相关文章!