
要使用 php 自动将数据从 csv 或 excel 文件传输到 mysql 和 postgresql 数据库,请按照以下步骤操作:
先决条件
-
安装必要的库:
- php 针对 mysql 和 postgresql 的 pdo 扩展。
- phpexcel 库(或 phpspreadsheet,如果可用,但我们将使用 phpexcel,因为它与 php 5.6 更兼容)。
下载 phpexcel 库并将其包含在您的项目目录中。
第 1 步:设置数据库连接
我们将使用 pdo 连接到 mysql 和 postgresql。
setattribute(pdo::attr_errmode, pdo::errmode_exception);
echo "connected to mysql successfully.
";
} catch (pdoexception $e) {
die("mysql connection failed: " . $e->getmessage());
}
// postgresql connection
$pghost = 'localhost';
$pgdb = 'pgsql_database';
$pguser = 'pgsql_user';
$pgpassword = 'pgsql_password';
try {
$pgconnection = new pdo("pgsql:host=$pghost;dbname=$pgdb", $pguser, $pgpassword);
$pgconnection->setattribute(pdo::attr_errmode, pdo::errmode_exception);
echo "connected to postgresql successfully.
";
} catch (pdoexception $e) {
die("postgresql connection failed: " . $e->getmessage());
}
?>
第 2 步:从 csv 或 excel 文件加载数据
我们将创建一个函数来读取 csv 或 excel 文件并将数据作为数组返回。
getactivesheet();
foreach ($sheet->getrowiterator() as $row) {
$rowdata = [];
$celliterator = $row->getcelliterator();
$celliterator->setiterateonlyexistingcells(false);
foreach ($celliterator as $cell) {
$rowdata[] = $cell->getvalue();
}
$data[] = $rowdata;
}
return $data;
} else {
throw new exception("unsupported file format");
}
}
?>
第3步:将数据传输到mysql和postgresql
定义函数以将数据插入 mysql 和 postgresql。此示例假设数据是数组的数组,其中每个内部数组代表数据库中的一行。
iWebShop是一款基于PHP语言及MYSQL数据库开发的B2B2C多用户开源免费的商城系统,系统支持自营和多商家入驻、集成微信商城、手机商城、移动端APP商城、三级分销、视频电商直播、微信小程序等于一体,它可以承载大数据量且性能优良,还可以跨平台,界面美观功能丰富是电商建站首选源码。iWebShop开源商城系统 v5.14 更新日志:新增商品编辑页面规格图片上传优化商品详情页面规格图片与主图切
prepare($query);
foreach ($data as $row) {
$stmt->execute($row);
}
echo "data inserted into mysql successfully.
";
}
function insertintopostgresql($pgconnection, $data) {
$query = "insert into your_pg_table (column1, column2, column3) values (?, ?, ?)";
$stmt = $pgconnection->prepare($query);
foreach ($data as $row) {
$stmt->execute($row);
}
echo "data inserted into postgresql successfully.
";
}
?>
第四步:把它们放在一起
从文件中加载数据,然后将其传递给每个函数以插入到 mysql 和 postgresql 中。
getMessage(); } ?>
执行示例
- 确保 mysql 和 postgresql 数据库和表(your_mysql_table、your_pg_table)已设置并具有正确的列(column1、column2、column3)。
- 将您的 csv 或 excel 文件放置在指定路径 ($filepath) 中。
- 从命令行或浏览器(如果在 web 服务器上)运行此 php 脚本。
此脚本将从指定文件中读取数据并将其插入到两个数据库中。
立即学习“PHP免费学习笔记(深入)”;
与我联系:@ linkedin 并查看我的作品集。
请给我的 github 项目一颗星 ⭐️










