php - 将 MySQL 数据库导出为 CSV,同时将 Unix 转换为日期

标签 php mysql unix csv

首先介绍一下背景故事。我有一个与自定义创建的票证系统配合使用的数据库。新票证通过使用 PHP 的 HTML 表单输入。

我需要能够根据用户在单独表单上选择的内容将某些结果导出到 CSV。

通过 Google 快速搜索 MySQL to CSV with PHP 即可打开此网站。

http://www.a2zwebhelp.com/export-data-to-csv .

我稍微修改了代码,以便查询不会选择表中的所有列,下面是我修改后的代码。

<?php

// Database Connection

$host="localhost";
$uname="REMOVED";
$pass="REMOVED";
$database = "REMOVED";  

$connection=mysql_connect($host,$uname,$pass); 

echo mysql_error();

//or die("Database Connection Failed");
$selectdb=mysql_select_db($database) or die("Database could not be selected");  
$result=mysql_select_db($database)
or die("database cannot be selected <br>"); 

// Fetch Record from Database

$output         = "";
$table          = "site_calls"; // Enter Your Table Name
$sql            = mysql_query("select call_id, call_first_name, call_email,   call_department, call_subject, call_status, call_user, call_date, call_date2 from $table WHERE (call_user = 15)");
$columns_total  = mysql_num_fields($sql);

// Get The Field Name

$columns =   ["call_id","call_first_name","call_email","call_department","call_subject","call_status","call_user","call_date","call_date2"];
for ($i = 0; $i < $columns_total; $i++) {
$heading    =   mysql_field_name($sql, $i);
$output     .= '"'.$heading.'",';
}
$output .="\n";

// Get Records from the table

while ($row = mysql_fetch_array($sql)) {
for ($i = 0; $i < $columns_total; $i++) {
$output .='"'.$row["$i"].'",';
}
$output .="\n";
}

// Download the file

$filename =  "TicketExport.csv";
header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);

echo $output;
exit;

?>

这几乎完全符合我的要求。唯一的问题是,由于时间/日期保存在数据库 (Unix) 中的方式,2 列 call_date 和 call_date2 的输出以 Unix 形式输出。我需要这些以 DD/MM/YY 或其他人类可读的格式显示。我可以使用 Excel 中的公式手动更改此设置,但这是客户可以访问的内容,并且他们需要能够读取日期。

此外,mysql 已弃用,是否需要对上述代码进行重大更改以使其在 mysqli 上运行。系统的其余部分是使用mysqli编写的,用于输入数据。

TL:博士。从 MYSQL 数据库导出一些列,需要使用 php 将 2 列从 Unix 转换为可读的日期/时间。

最佳答案

试试这个:

while ($row = mysql_fetch_array($sql)) {
  for ($i = 0; $i < $columns_total; $i++) {
    $heading = mysql_field_name($sql, $i);
    if ($heading == 'call_date' || $heading == 'call_date2') {
      $output .= '"'.date('d/m/y', strtotime($row["$i"])).'",';
    }
    else {
      $output .='"'.$row["$i"].'",';
    }
  }
  $output .="\n";
}

关于php - 将 MySQL 数据库导出为 CSV,同时将 Unix 转换为日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29631461/

相关文章:

php - Zend View Helper Navigation 移除事件分支,因此面包屑不会显示

mysql - 从 SQL 查询生成总和小于特定金额的值列表

linux - 如何检测文件是 XLS 还是 XLSX

c - 使用 opendir() 获得的目录流中的条目顺序

c++ - 为什么使用 rand() 有更高数字的概率

php - 根据用户输入编写包含变量 WHERE 的查询

php - 与关联数组中的 array_combine/两个数组相反的函数

mysql - 如何从MySQl中的联合表中过滤掉一个值?

php - 如何加快 1800 行 PHP 包含的速度?它使我的页面加载速度减慢到 10 秒/ View

mysql - 在 MySQL 中将二进制字符串转换为 bigint?