4

我目前正在通过这个 sqlplus 脚本假脱机一个管道文件:

    set feedback off
    set echo off
    set verify off
    set pagesize 0
    set heading off
    set termout off
    set trim on
    set wrap on
    set trimspool on
    set linesize 9000
    spool c:\exp3.txt
    select
    to_char(D_DTM, 'mm-dd-yyyy hh24.mi.ss')||'|'||
    DAYOFWEEK||'|'||"24HOUR"||'|'||TECHNOLOGY||'|'||VOICEDATA||'|'||MRKT_NM||'|'||REGION_NM||'|'||CLUSTER_NM||'|'||
    CLUSTER2_NM||'|'||BSC_NM||'|'||BTS_ID||'|'||BSC_BTS||'|'||CSCD_ID||'|'||CSCD_NM||'|'||SECT_SEQ_ID||'|'||BND_ID||'|'||
    FA_ID||'|'||ATT_CNT||'|'||AXS_F_CNT||'|'||CE_BLK_CNT||'|'||CUST_BLK_CNT||'|'||DRP_CALL_CNT||'|'||HHI_ATT_CNT||'|'||
    HHI_BAFRM_CNT||'|'||HHI_CALL_SETUP_SXS_CNT||'|'||MBL_ORG_CNT||'|'||MBL_TER_CNT||'|'||NON_BTS_EQ_BLK_CNT||'|'||
    PRIM_CALL_ERL||'|'||PWR_BLK_CNT||'|'||SFUL_CALL_CNT||'|'||SILENT_RETRY_CNT||'|'||T1_BHL_BLK_CNT||'|'||WCD_BLK_CNT||'|'||
    SMS_ATT_CNT||'|'||SMS_SXS_CNT||'|'||CTRL_CH_USG_CNT||'|'||CTRL_SL_USG_CNT||'|'||DO_SECT_PHL_FWD_PS_TMS||'|'||
    DO_SECT_PHL_REV_PS_TMS||'|'||EUSR_CONN_SETUP_ATT_CNT||'|'||EUSR_CONN_SETUP_F_CNT||'|'||FWD_D_TRANSD_QTY||'|'||
    MAC_ID_BLK_CNT||'|'||MAC_ID_UTIL_RT||'|'||MS_RQST_CNT||'|'||MS_RQST_D_QTY||'|'||NORM_CONN_CLS_CNT||'|'||
    NORM_SESS_RLS_CNT||'|'||RAB_SET_CNT||'|'||RCVD_RAB_CNT||'|'||REV_AIR_PER_BAD_FRM_CNT||'|'||REV_AIR_PER_TRSF_D_QTY||'|'||
    REV_D_TRANSD_QTY||'|'||RNC_BLK_CNT||'|'||SESS_ATT_CNT||'|'||SESS_CONF_SXS_CNT||'|'||SL_USG_CNT||'|'||MAX_USER_CNT||'|'||
    AVG_USER_CNT||'|'||MOU_TMS||'|'
    from ds3r_fh_all_fa_lvl_kpi
    where D_DTM = to_date('8/19/2013', 'mm/dd/yyyy');

但我不知道如何将列名作为标题包含在文件中。我怎么做?

4

6 回答 6

9
set heading on
set pagesize 0 embedded on
  • 包括标题
  • 无限页面大小
于 2016-05-27T16:05:02.110 回答
3

您应该将 设置为pagesize非零数字,这样您的标题就会显示出来。您设置的数字可能取决于您拥有的行数。如果根据以下行将其设置为 100:

set pagesize 100

然后将在标题下打印 100 行,然后在接下来的 100 行中重复列标题。50000 中提到的最大值。也设置heading为 on

set heading on

否则它不会显示标题,尽管页面大小不为零。还请记住,当您以这种方式选择列时,它们不会被填充,因此标题可能会显得不合适。

于 2013-08-22T10:46:30.160 回答
2

我会建议你一个更聪明的解决方案,因为我一直在研究这个问题。您可以从自己的文本中创建它,而不是显示对我来说不是一个很好的解决方案的标题。只需添加一个 SELECT 和 UNION 就可以很好地做到这一点:

SELECT 'CHANNEL_CODE ; ISDN ; ACTIVATION_DATE ; TOTAL_MONEY ' from dual
union all
SELECT * ... (your query here)

希望这会有所帮助。

于 2017-10-26T07:45:06.043 回答
0

将 pagesize 设置为 0 会关闭 sql*plus 中的列标题。

尝试将其设置为 50000

set pagesize 50000

我认为这是最大值(我可能错了!)

于 2013-08-20T19:07:12.363 回答
0

.sql 文件顶部的以下设置有效。

设置页面大小 50000
设置标题

于 2015-02-04T18:50:46.447 回答
0

设置 pagesize 0 嵌入

线轴后添加以上行

于 2016-08-17T06:17:01.863 回答