免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2851 | 回复: 4
打印 上一主题 下一主题

关于sqlplus输出问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-07-22 10:19 |只看该作者 |倒序浏览
s -s <<!
set term off verify off feedback off echo off
set head off
spool index.tmp1
select INDEX_NAME from dba_indexes where OWNER='HDARUN';
spool off
!
sleep 1
cat index.tmp1 | grep -v  "SQL> " | grep -v spool | grep -v "^$" index.tmp1 | grep -v 'SQL>'  > index.tmp
cat /dev/null > createindex.sql
while read LINE
do
s -s <<! >>createindex.sql
set term off verify off feedback off echo off
set head off
set long 999999
set linesize 200
select dbms_metadata.get_ddl('INDEX','$LINE','HDARUN') from dual;
!
done < index.tmp

SQL*Plus: Release 10.2.0.4.0 - Production on Fri Jul 22 09:43:22 2011

Copyright (c) 1982, 2007, Oracle.  All Rights Reserved.


Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> SQL> SQL> SQL> SQL>

  CREATE INDEX "HDARUN"."IND_INFO_IND" ON "HDARUN"."IND_INFO" ("CUSTOMERID")
  PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS
  STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
  PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)
  TABLESPACE "INDX"


怎么把
SQL*Plus: Release 10.2.0.4.0 - Production on Fri Jul 22 09:43:22 2011

Copyright (c) 1982, 2007, Oracle.  All Rights Reserved.


Connected to:
Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> SQL> SQL> SQL> SQL
这些东西过滤掉 谢谢!!!!!!

论坛徽章:
0
2 [报告]
发表于 2011-07-22 10:35 |只看该作者
自己先顶顶

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
3 [报告]
发表于 2011-07-22 14:32 |只看该作者
要求讲的不太清楚。大概的写一下先
  1. awk -v t=1 '/SQL\*Plus:/{t=0}/SQL> SQL>/{getline;t=1}t' infile
复制代码

论坛徽章:
0
4 [报告]
发表于 2011-07-22 16:25 |只看该作者
sqlplus -s

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
5 [报告]
发表于 2011-07-22 20:59 |只看该作者
我以前也干过类似的事情,当时写的:
  1. awk '/^SQL/{next}/^  CREATE /{gsub(/^  /,"");printf ";\n"$0;next}{printf $0}END{print ";"}' createindex.sql > createindex_new.sql
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP