我得到了两张表门票和回复。从两张表中将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号机票,并在下一行中回复1号机票。然后票#2和票#2等的回复。但是,档案是不同的,所以我不知道是否可以做到。 –