在 PHP 中高效地将 MySQL 查询转换为 CSV
要将 MySQL 查询转换为 PHP 中的 CSV,一种流行的方法是利用 SQL 的 INTO输出文件命令。通过这种方法,您可以指定输出目标和格式选项:
SELECT * INTO OUTFILE "/path/to/file.csv" FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY "\n" FROM my_table;
另一个有效的选项是以编程方式获取查询结果并手动构建 CSV:
$select = "SELECT * FROM my_table"; $export = mysql_query($select); $fields = mysql_num_fields($export); $header = ''; for ($i = 0; $i < $fields; $i++) { $header .= mysql_field_name($export, $i) . "\t"; } $data = ''; while ($row = mysql_fetch_row($export)) { $line = ''; foreach ($row as $value) { $value = str_replace('"', '""', $value); $line .= '"' . $value . '"' . "\t"; } $data .= trim($line) . "\n"; } header("Content-type: application/octet-stream"); header("Content-Disposition: attachment; filename=my_file.csv"); print "$header\n$data";
此方法允许您自定义字段分隔符和引号字符以满足您的特定要求。
以上是如何在PHP中高效地将MySQL查询结果导出为CSV?的详细内容。更多信息请关注PHP中文网其他相关文章!