我有一个包含一些常见字段的时间表数据库表。
id, client_id, project_id, task_id, description, time, date
还有更多,但这就是它的要点。
我有一夜之间在该表上运行导出到 CSV 文件,以便为用户提供其数据的备份。它还用作带有一些自定义报告的宏 Excel 文件的数据导入。
这一切都适用于我使用 php 循环浏览时间表并将这些行打印到文件中。
问题在于大型数据库可能需要数小时才能运行,这是不可接受的。所以我用 MySQLINTO OUTFILE
命令重写了它,它把运行时间缩短到几秒钟,这很棒。
现在的问题是我似乎无法在描述字段中转义所有新行字符等。实际上,用户可以在此处键入任何字符组合,包括回车/换行。
这是我拥有的 MySQL 代码片段:
SELECT id,
client,
project,
task,
REPLACE(REPLACE(ifnull(ts.description,''),'\n',' '),'\r',' ') AS description,
time,
date
INTO OUTFILE '/path/to/file.csv'
FIELDS ESCAPED BY '""'
TERMINATED BY ',' ENCLOSED BY '"'
LINES TERMINATED BY '\n'
FROM ....
但...
当我尝试查看输出文件的源时,文件中仍然存在换行符,因此 Excel 的 CSV 导入会破坏 Excel 向导创建的所有花哨的宏和数据透视表。
关于最佳行动方案的任何想法?