如何在 sql*plus 中修复我的假脱机 csv 文件中的格式

Posted

技术标签:

【中文标题】如何在 sql*plus 中修复我的假脱机 csv 文件中的格式【英文标题】:How do I fix the formatting in my spooled csv file in sql*plus 【发布时间】:2021-07-30 09:05:11 【问题描述】:

我正在使用以下脚本将 sql 查询的输出假脱机到 csv 文件。该查询从视图中提取数据。我的sql*plus版本是12.1.0.2.0

set colsep ,
set headsep off
set pagesize 0
set trimspool on
set NULL ' '
spool myfile.csv
select * from my_view;
spool off

该表有几列具有空值,我需要生成如下所示的输出。

12345,,,ABC,01-JAN-2020

但我的实际输出是这样的。

    12345


A B C   ,01-JAN-2020

为什么所有这些空格都出现在列数据之间?对于空值,插入新行并且缺少逗号。 我该如何解决这个问题?

【问题讨论】:

spool myfile.csv之前添加这个:set markup csv on 【参考方案1】:

我修改了 select * 语句如下以获得所需的输出。

select ColA||','||ColB||','||ColC||','||ColD||','||ColE from my_view;

仍然出于好奇,我想知道是否还有其他方法可以达到同样的效果。 同样使用上面的查询会弄乱标题。

【讨论】:

以上是关于如何在 sql*plus 中修复我的假脱机 csv 文件中的格式的主要内容,如果未能解决你的问题,请参考以下文章

ORACLE 如何使用具有动态假脱机位置的假脱机

如何使用 SQL Developer 假脱机到 CSV 文件?

如何将从文件上传小部件上传的假脱机文件传递到 C FILE *f 指针

在管道分隔的 sqlplus 中带有列标题的假脱机

Oracle SQL 自动并行假脱机

如何使操作系统命令的标准错误以“!”运行转到 Sql*plus 线轴?