gpt4 book ai didi

php - Mysql 结果不存储在文件中

转载 作者:行者123 更新时间:2023-11-30 00:04:17 25 4
gpt4 key购买 nike

我有一个 mysql 语句,我想将其获取的数据以选项卡格式存储在 csv 文件中。我已使用以下语句,但当我运行文件并且没有错误文件时,它不会创建和存储结果。

  $mytry =  "SELECT * FROM table WHERE `assigned` = '$id'
INTO OUTFILE '/inactive/orders.csv'
FIELDS TERMINATED BY ','
ENCLOSED BY '\"'
LINES TERMINATED BY '\n'";

mysql_query($mytry);

或者有一种方法可以写入目录中的文件而不提示用户下载,这可以工作,但会提示

    $sQuery="SELECT * FROM table WHERE `assigned` = '$id'";

$rResult = mysql_query( $sQuery) or die();
$count = mysql_num_fields($rResult);

$html = '<table border="1"><thead><tr>%s</tr><thead><tbody>%s</tbody></table>';
$thead = '';
$tbody = '';
$line = '<tr>%s</tr>';
for ($i = 0; $i < $count; $i++){
$thead .= sprintf('<th>%s</th>',mysql_field_name($rResult, $i));
}


while(false !== ($row = mysql_fetch_row($rResult))){
$trow = '';

foreach($row as $value){
$trow .= sprintf('<td>%s</td>', $value);
}

$tbody .= sprintf($line, $trow);

}


header("Content-type: application/vnd.ms-excel; name='excel'");
header("Content-Disposition: filename=exportfile.xls");
header("Pragma: no-cache");
header("Expires: 0");

print sprintf($html, $thead, $tbody);
exit;

最佳答案

您可能想查看以下 PHP 函数:http://php.net/manual/en/function.fputcsv.php

使用查询获取数据,然后将其保存到变量中。然后,使用 fputcsv 将数据存储到文件中。

此外,我不鼓励使用 mysql_query,因为它现在已弃用(以及 mysql_* 系列的其余部分) )。此外,您的代码容易受到 SQL 注入(inject)攻击。阅读有关使用 PDO for database interaction 的信息.

更多推荐阅读内容可帮助您走上正轨:http://www.phptherightway.com/#databases

编辑:根据您在代码示例中显示的内容,您只需将 HTML 页面输出到浏览器,由于 Content-Disposition ,该页面会立即下载您设置的标题。

关于php - Mysql 结果不存储在文件中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24725979/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com