0

我有一个名为demo_db的数据库 ,其中包含以下表格:

user
  Id
  Name

history
  Id
  userId
  report

start_test
  Id
  userId
  score

final_test
  Id
  userId
  score

如何在 MySQL 中使用 INTO OUTFILE 将所有表导出到 CSV 文件中?所以我可以有列名和数据下方,我希望能够添加过滤器,如果有办法将每个表添加到同一文件中的新选项卡中......或者如果我可以显示所有每个用户在一行中的数据?

我不能做类似的事情:选择用户。, 历史。, start_test.*, final_test.* INTO OUTFILE FROM user, history, start_test, final_test

我用 mysqldump 做到了,但它没有按我的意愿呈现数据。

我正在用 PHP 做这个。

4

4 回答 4

2

没有直接执行此操作的命令,您需要模拟 mysqldump 的行为并以您想要的方式输出 CSV。

$FILE = fopen("output.csv", "w");
mysql_connect($server, $login, $password);
$res = mysql_query("SHOW TABLES FROM $db");
$tables = array();
while($row = mysql_fetch_array($res, MYSQL_NUM)) {
    $tables[] = "$row[0]";
}
foreach($tables as $table) {
    $columns = array();
    $res = mysql_query("SHOW COLUMNS FROM $table");
    while($row = mysql_fetch_array($res, MYSQL_NUM)) {
        $columns[] = "$row[0]";
    }
    fwrite($FILE, implode(",", $columns); fwrite("\n");
    $resTable = mysql_query("SELECT * FROM $table");
    while($row = mysql_fetch_array($resTable, MYSQL_NUM)) {
        fwrite($FILE, implode(",", $row)); fwrite("\n");
    }
}

MYSQL_NUM 用于为您提供数字索引数组。

如果您不想输出到文件,而是直接从网站下载到您的计算机,请将以下行添加到脚本的开头:

header('Content-Type: text/csv; name="filename.csv"');
header('Content-Disposition: attachment; filename="filename.csv"');

将 fwrite 更改为 echo 或 print。

哦,我在输出中添加了一些换行符,因为我确定您不会想要一条大长线。

于 2013-05-10T15:14:15.610 回答
0

此片段取自http://dev.mysql.com/doc/refman/5.6/en/select-into.html

SELECT a,b,a+b INTO OUTFILE '/tmp/result.txt'
  FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
  LINES TERMINATED BY '\n'
  FROM test_table;
于 2013-05-10T15:57:47.730 回答
0

如果您使用的是 phpmyadmin

然后转到导出->单击自定义-display all possible options

您会在下面找到复选框:Put columns names in the first row。检查以获取第一行中的列名,在下面您将获得数据。

于 2013-05-10T15:02:35.387 回答
0
CREATE VIEW MY_VIEW
AS
SELECT user.*, history.*, start_test.*, final_test.*
FROM
user, history, start_test, final_test
WHERE user.id = history.userId
AND user.id = start.userId
AND user.id = final.userId

在 phpmyadmin 中使用导出工具转储视图的内容

于 2013-05-10T15:20:51.300 回答