4

假设我有带列的表 A

      col1   col2   col3   col4
      -------------------
      sajal  singh  28     IND
      hello  how    are    you

我想将数据导出到一个平面文件中,列之间没有空格或制表符所以输出应该是

      cat dump
      sajalsingh28IND
      hellohowareyou

我尝试过的。我写了一个脚本

      #!/usr/bin/bash

      #the file where sql output will go
      OUT=report.txt
      >$OUT
      DESC=desc.txt
      >$DESC

      sqlplus -s "xxx/xxx@xxx" << END_SQL > /dev/null

      set pages 0
      set feedback off
      set heading off
      set trimspool off
      set termout off
      set verify off
      set wrap off

      SPOOL $DESC

      Select * from table_name;

      SPOOL OFF

      END_SQL

但是我在多行中得到一行的输出,并带有制表符/空格

  1. 所以问题是我该如何解决这个问题?和
  2. 我发现了一些数据泵实用程序,例如 expdp。我可以在 Unix 中使用它吗?如果是,我怎样才能以这种格式实现转储?

谢谢你

4

4 回答 4

4

如果您已经有 CSV 转储,则可以运行以下命令:

awk 'BEGIN{FS=",";OFS=""}{$1=$1}1' csv.dump > new.dump 

未经测试:

SET HEADING OFF
SET FEEDBACK OFF
SPOOL $DESC

SELECT col1 ||''|| col2 ||''|| col3 FROM table_name;

SPOOL OFF;
于 2013-06-20T06:21:30.917 回答
3

从“简化的 oracle 视图”到的“普通”字符:

sed -n '3,$ s/\s//gp' file
$猫文件
      col1 col2 col3 col4
      ------------------
      萨哈尔·辛格 28 IND
      你好吗
$sed -n '3,$ s/\s//gp' 文件
sajalsingh28IND
你好吗

说明:将第 3 行到 EOF 的所有空格(不是换行符)替换为“nothing”。

于 2013-06-20T06:35:31.227 回答
2

如果您想要填充列但列之间没有额外的空格,您可以执行以下操作:

set colsep ""

默认是在双引号之间有一个空格,这会在列之间放置一个空格。您可能还想这样做:

set tab off

...以确保填充中的多个空格不会转换为制表符,这看起来很适合显示,但解析文件会很痛苦。

如果您根本不需要空格,要在 SQL*Plus 中执行此操作,您需要连接列:

 select col1 || col2 || col3 || col4 from table_name;

如果您在列之间放置分隔符(例如,使其成为 CSV),这很有用,但我不知道如果您在没有分隔符的情况下将所有内容压缩在一起,您将能够处理文件中的数据。

于 2013-06-20T11:05:21.243 回答
2

所以这就是我想出的:它将转储 oracle 数据,列之间没有任何空格等,同时保留数据中的空格。我以为我会和你分享。

#!/usr/bin/bash
#the file where sql output will go
OUT=report.txt
>$OUT
DESC=desc.txt
>$DESC

TABLE_NAME=$1


###GET DESCRIBE####

s=""
#######################
sqlplus -s "xxx/xxx@xxx" << END_SQL > /dev/null

set pages 0
set feedback off
set heading off
set trimspool off
set termout off
set verify off
set wrap off

SPOOL $DESC

desc $TABLE_NAME;

SPOOL OFF

END_SQL
#######################

for i in `cat $DESC|awk -F" " '{print $1}'|grep -v -i name|grep -v -`
do
s=$s"trim($i)||'|'||"
done

s=`echo $s|sed "s/||'|'||$//g"`
echo $s

#######################
#sqlplus - silent mode
#redirect /dev/null so that output is not shown on terminal
sqlplus -s "xxx/xxx@xxx" << END_SQL > /dev/null

set pages 0
set feedback off
set heading off
set trimspool off
set termout off
set verify off
set colsep ""
set tab off
set lines 1500

SPOOL $OUT

select $s from $TABLE_NAME;
SPOOL OFF

END_SQL
#######################


cat $OUT|sed "s/|//g"|sed "s/ *$//g" >$OUT.new
mv $OUT.new $OUT

echo Finished writing report $OUT
于 2013-06-21T09:52:19.833 回答