免费注册 查看新帖 |

Chinaunix

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

提取所有table上index的创建脚本 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-03 17:07 |只看该作者 |倒序浏览
我想提取oracle 里面某个user的所有table上index的创建脚本, 请问如何提取? 谢谢

论坛徽章:
0
2 [报告]
发表于 2008-12-03 17:20 |只看该作者
数据来源:DBA_INDEXES,DBA_IND_COLUMNS
其他的部分就是用你熟悉的工具,比如pl/sql或proc*c或perl或php之类的写程序吧

论坛徽章:
0
3 [报告]
发表于 2008-12-03 17:46 |只看该作者
请问oracle 有没有一个工具可以直接提取index生成脚步呢?

论坛徽章:
0
4 [报告]
发表于 2008-12-09 10:45 |只看该作者
两种方法,一种可以用DBA_INDEXES,DBA_IND_COLUMNS ,用sql语句自己拼接,还有一种是
DBMS_METERDATA,比如得到一个用户下的索引ddl

SET SERVEROUTPUT ON
SET LINESIZE 1000
SET FEEDBACK OFF
set long 999999
SET PAGESIZE 0  
EXECUTE DBMS_METADATA.SET_TRANSFORM_PARAM(DBMS_METADATA.SESSION_TRANSFORM,'STORAGE',false);

SELECT DBMS_METADATA.GET_DDL(U.OBJECT_TYPE, u.object_name)
  FROM USER_OBJECTS u
where U.OBJECT_TYPE IN ('INDEX');

[ 本帖最后由 anton 于 2008-12-9 11:00 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2008-12-09 15:16 |只看该作者
楼上正解
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP