Eine Möglichkeit wäre, das erste Ergebnis assoziativ abzurufen, diese assoziativen Indizes sind sowieso Spalten. Wenden Sie array_keys
an Um diese zu erhalten, fügen Sie zuerst die Header hinzu, dann die erste abgerufene Zeile und den Rest in einer Schleife.
// first set
$first_row = $STH->fetch(PDO::FETCH_ASSOC);
$headers = array_keys($first_row);
// $headers = array_map('ucfirst', $headers); // optional, capitalize first letter of headers
fputcsv($fp, $headers); // put the headers
fputcsv($fp, array_values($first_row)); // put the first row
while ($row = $STH->fetch(PDO::FETCH_NUM)) {
fputcsv($fp,$row); // push the rest
}
fclose($fp);