2016-05-31 45 views
-1

我得到了两张表门票回复从两张表中将MYSQL导出为.csv

门票得到这个字段: ID,DNAME,MNAME,主题,优先级,消息,日期,last_reply,状态,close_mname,cdfileds

回复得到这个的Fileds: ID,TID MNAME,消息,日期

这些表是支持票。 我想将表格导出为CSV。 这是我使用的代码。

<?php 
/* vars for export */ 
// database record to be exported 
$db_record = 'trxp_tickets'; 
$db_record2 = 'trxp_replies'; // added by me 
// 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 = "xxxxx"; 
$password = "xxxxx"; 
$database = "xxxxxx"; 
// 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()); 
// create empty variable to be filled with export data 
$csv_export = ''; 
// query to get data from database 
$query = mysql_query("SELECT id,dname,mname,subject,priority,message,date,last_reply,status,close_mname,cdfields 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).';'; 
} 
// newline (seems to work both on Linux & Windows servers) 
$csv_export.= ' 
'; 
// loop through database query and fill export variable 
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); 
?> 

在代码中,它不包括在第二个表中时,我做了SELEC,双打结果。尝试使用UNION和UNION ALL但不起作用。 我想留在下面列出的CSV每个票的回复。

+1

好的,但你想如何导出数据?两个文件?一个文件包含两个表中的所有列?另外一个选择? –

+0

一个文件。我希望我能买到1号机票,并在下一行中回复1号机票。然后票#2和票#2等的回复。但是,档案是不同的,所以我不知道是否可以做到。 –

回答

0

改变你的SQL从两个表中获取数据:

$query = mysql_query("SELECT 
          r1.id, r1.dname, r1.mname, r1.subject, 
          r1.priority, r1.message, 
          DATE_FORMAT(FROM_UNIXTIME(r1.date), '%d/%m/%Y') as r1_date, 
          r1.last_reply, r1.status, r1.close_mname, 
          r1.cdfields, 
          r2.id, r2.tid, r2.mname, 
          r2.message 
          DATE_FORMAT(FROM_UNIXTIME(r2.date), '%d/%m/%Y') as r2_date, 
        FROM ".$db_record." r1 
       INNER JOIN ".$db_record2." r2 
         ON r1.id = r2.tid 
          ".$where."); 

这应该做的伎俩。

mysql_ *函数已被弃用。您应该更改为mysqli_ *或PDO。 (http://php.net/manual/en/function.mysql-query.php

+0

谢谢。代码有效,但有一个问题,它会在CVS文件中复制结果。也许更容易在第一列显示Tickets Fileds并继续回复filelds。 '例如:id,dname,mname,主题,.... id,tid,mname,....'在一行中,票据文件和答复。 –

+0

改变你的选择只获取你需要的数据。 'SELECT r1.id,... FROM ...' –

+0

仍然重复。我不知道为什么,但每张票都是重复8次,即总票数。另一个问题是可以在选择时更改日期的格式?我有这种日期格式:1459195461,我想要dd/mm/yyyy。谢谢Felippe。 –