【发布时间】:2014-11-13 15:59:25
【问题描述】:
我有一个包含两个表的数据库:core_members 和 core_fields_content。
core_members 有以下列:member_id、name、email core_pfields_content 包含以下列:member_id、field_1、field_2 等。
我想根据查询中提供的自定义字段值输出选择成员姓名和电子邮件的查询结果并将其导出到 csv 文件。
我希望输出显示在列中,但是在 excel 中打开时,下面的代码在一个单元格中为我提供了以下输出:名称;电子邮件;测试名称;testemail@test.com;
如何更改代码以输出到列中,以列名作为标题?
<?php
$csv_fileName = 'forumuserlist_'.date('Y-m-d').'.csv';
// database variables
$hostname = "localhost";
$user = "";
$password = "";
$database = "";
// Database connecten voor alle services
mysql_connect($hostname, $user, $password)
or die('Could not connect: ' . mysql_error());
mysql_select_db($database)
or die ('Could not select database ' . mysql_error());
$csv_export = '';
$query = mysql_query("SELECT m.name, m.email FROM core_members m, core_pfields_content p WHERE m.member_id=p.member_id AND p.field_4='LPC'");
$field = mysql_num_fields($query);
// create line with field names
for($i = 0; $i < $field; $i++) {
$csv_export.= mysql_field_name($query,$i).';';
}
$csv_export.= '';
while($row = mysql_fetch_array($query)) {
// create line with field values
for($i = 0; $i < $field; $i++) {
$csv_export.= $row[mysql_field_name($query,$i)].';';
}
$csv_export.= '';
}
// Export the data and prompt a csv file for download
header("Content-type: text/x-csv");
header("Content-Disposition: attachment; filename=".$csv_fileName."");
echo($csv_export);
?>
【问题讨论】:
-
拜托,don't use
mysql_*functions,它们不再维护,而是officially deprecated。改为了解prepared statements,并使用PDO 或MySQLi。您还想Prevent SQL Injection! -
@JayBlanchard 老实说我不知道自己在做什么,这是我在互联网上找到的代码,然后编写了我自己的查询!