【问题标题】:Export MySQL data to .csv using PHP使用 PHP 将 MySQL 数据导出到 .csv
【发布时间】:2014-03-07 13:52:02
【问题描述】:

我正在将数据导出到.csv 文件,它运行良好,但我有一个小问题。我从表中获取namegender,但对于性别,我将id 保存在我的数据库中(即1 = Male2 = Female)。我下面的代码给了我性别的 id,我该如何解决?男性返回 1,女性返回 2:

$rows = mysql_query("SELECT `name`, `gender` FROM TABLE");

while ($row = mysql_fetch_assoc($rows)) {
    fputcsv($output, $row);
}

【问题讨论】:

  • 显然不是,幸运的是,无论如何总会有人发布解决方案。

标签: php mysql export-to-csv fputcsv


【解决方案1】:

试试这个:

$rows = mysql_query("SELECT `name`, `gender` FROM TABLE");

while ($row = mysql_fetch_assoc($rows)) {

    if($row['gender'] == 1) {
        $row['gender'] = 'Male'; 
    } else {
        $row['gender'] = 'Female'; 
    }

    // Or ternary condition
    // $row['gender'] = ($row['gender'] == 1 ? 'Male' : 'Female');

    fputcsv($output, $row);
}

【讨论】:

  • 三元条件对我来说似乎很好@ncrocfer ;)
【解决方案2】:
<?php

    $db_record = 'yourRecod';
    // optional where query
    $where = 'WHERE 1 ORDER BY 1';
    // filename for export
    $csv_fileName = 'db_export_'.$db_record.'_'.date('Y-m-d').'.csv';

    // database variables
    $hostname = "localhost";
    $user = "yourUserName";
    $password = "yourPassword";
    $database = "yourDataBase";

    // 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 * FROM ".$db_record." ".$where);
    $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);
?>

我给你完整的示例代码,我使用 PHP 将 MySql 数据导出到 .CSV

【讨论】:

  • 这不会给我每个新行的换行符:-(
【解决方案3】:

在您的 SQL 中使用 IF statement 来最小化 PHP 逻辑:

SELECT `name`, IF(gender=1,'Male','Female') as 'gender' FROM TABLE

【讨论】:

    猜你喜欢
    • 2011-12-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-01-25
    • 2013-09-15
    • 2014-10-20
    相关资源
    最近更新 更多