PHP | fputcsv:生成的文件只填充了字段标题,但没有记录

时间:2015-11-02 04:38:18

标签: php fputcsv

我无法弄清楚为什么这段代码只生成一个包含字段标题但没有记录的文件。

文件内容:

"Article ID",Shoppergroupname,"Promotion Price",VAT-Code,"Article Currency","Promotion Start Date","Promotion End Date"

正如您所看到的,没有任何记录被导出"和数据库表不是很老实!

顺便说一句,我也想摆脱字段标题引号。

如果有人帮我解决这个问题,我将不胜感激。提前谢谢。

马克

@KateMihalikova提供的解决方案

// Create connection
$conn = new mysqli($databasehost, $databaseusername, $databasepassword, $databasename);

// Check connection
if (mysqli_connect_errno()) {
exit('Connect failed: '. mysqli_connect_error());
}
echo "Connected successfully | ";

// Create filename
date_default_timezone_set('Europe/Zurich');
$today = date("YmdHis"); 
$csvname = "WS_PRICE_IMPORT-".$today.".csv";
$csvfullname = '/var/.../'.$csvname; 


// create a file pointer connected to the output stream
$output = fopen($csvfullname, 'a+');

// output the column headings
fputcsv($output, array('Article ID', 'Shoppergroupname', 'Promotion Price', 'VAT-Code', 'Article Currency', 'Promotion Start Date', 'Promotion End Date'));

 // fetch the data
$sql = "SELECT `Article ID`, `Shoppergroupname`, `Promotion Price`, `VAT-Code`, `Article Currency`, `Promotion Start Date`, `Promotion End Date` FROM jos_temppriceimport";
$result = $conn->query($sql);

if (!$result) {
echo "Unable to execute query in the database : " . mysql_error();
exit;
}

if ($result->num_rows == 0) {
echo "No record found, no record to export in CSV.";
exit;
}

// loop over the rows, outputting them
while ($row = $result->fetch_row()) fputcsv($output, $row);

PS:带有空格的字段名由数据提供者提供。

2 个答案:

答案 0 :(得分:1)

您正在循环SQL语句。你需要循环遍历你的结果。

while ($row = mysqli_fetch_assoc($result)) fputcsv($output, $row);

答案 1 :(得分:1)

代码中的主要问题是混合了程序mysql,程序mysqli和面向对象mysqli。它们很相似,但不能混合。

我们理解主要问题是在while循环中。

while ($row = mysql_fetch_assoc($rows)) fputcsv($output, $row);
迭代一点之后,面向对象的表示法存在问题,其中使用对象方法而不是具有属性的函数,但该属性保留在那里。 http://phpfiddle.org/main/code/jcbx-7c0n

while ($row = $result->fetch_row($result)) fputcsv($output, $row); // forgotten attribute
while ($row = $result->fetch_row()) fputcsv($output, $row);        // working just fine