通过shell脚本得到数据字典的信息

简介: 在平时的工作中,可能需要查询一些数据字典的信息,比如数据字典对应的基表信息,可以得到更多数据库内部的一些详细信息。 比如user_objects这个数据字典视图,里面可能就包含很多的信息。
在平时的工作中,可能需要查询一些数据字典的信息,比如数据字典对应的基表信息,可以得到更多数据库内部的一些详细信息。
比如user_objects这个数据字典视图,里面可能就包含很多的信息。

首先可以得到,它是一个视图,然后在public上创建了对应的同义词,但是在不用用户使用的使用,查出的结果会不相同,这个其实是根据类似环境变量的一套东西来实现的。
   where l.owner# = userenv('SCHEMAID'),它会锁定当前的schema。

OWNER                           OBJECT_ID DATA_OBJECT_ID OBJECT_NAME                    OBJECT_TYPE
------------------------------ ---------- -------------- ------------------------------ -------------------
SYS                                  3305                USER_OBJECTS                   VIEW
PUBLIC                               3306                USER_OBJECTS                   SYNONYM

synonym_details

OWNER                          SYNONYM_NAME
------------------------------ ------------------------------
PUBLIC                         USER_OBJECTS

view_details

VIEW_NAME                      TEXT
------------------------------ --------------------------------------------------------------------------------
USER_OBJECTS                   select o.name, o.subname, o.obj#, o.dataobj#,
                                      decode(o.type#, 0, 'NEXT OBJECT', 1, 'INDEX', 2, 'TABLE', 3, 'CLUSTER',
                                                     4, 'VIEW', 5, 'SYNONYM', 6, 'SEQUENCE',
                                                     7, 'PROCEDURE', 8, 'FUNCTION', 9, 'PACKAGE',
                                                     11, 'PACKAGE BODY', 12, 'TRIGGER',
                                                     13, 'TYPE', 14, 'TYPE BODY',
                                                     19, 'TABLE PARTITION', 20, 'INDEX PARTITION', 21, 'LOB',
                                                     22, 'LIBRARY', 23, 'DIRECTORY',  24, 'QUEUE',
                                                     28, 'JAVA SOURCE', 29, 'JAVA CLASS', 30, 'JAVA RESOURCE',
                                                     32, 'INDEXTYPE', 33, 'OPERATOR',
                                                     34, 'TABLE SUBPARTITION', 35, 'INDEX SUBPARTITION',
                                                     40, 'LOB PARTITION', 41, 'LOB SUBPARTITION',
                                                     42, NVL((SELECT 'REWRITE EQUIVALENCE'
                                                              FROM sum$ s
                                                              WHERE s.obj#=o.obj#
                                                                    and bitand(s.xpflags, 8388608) = 8388608),
                                                             'MATERIALIZED VIEW'),
                                                     43, 'DIMENSION',
                                                     44, 'CONTEXT', 46, 'RULE SET', 47, 'RESOURCE PLAN',
                                                     48, 'CONSUMER GROUP',
                                                     51, 'SUBSCRIPTION', 52, 'LOCATION',
                                                     55, 'XML SCHEMA', 56, 'JAVA DATA',
                                                     57, 'EDITION', 59, 'RULE',
                                                     60, 'CAPTURE', 61, 'APPLY',
                                                     62, 'EVALUATION CONTEXT',
                                                     66, 'JOB', 67, 'PROGRAM', 68, 'JOB CLASS', 69, 'WINDOW',
                                                     72, 'SCHEDULER GROUP', 74, 'SCHEDULE', 79, 'CHAIN',
                                                     81, 'FILE GROUP', 82, 'MINING MODEL',  87, 'ASSEMBLY',
                                                     90, 'CREDENTIAL', 92, 'CUBE DIMENSION', 93, 'CUBE',
                                                     94, 'MEASURE FOLDER', 95, 'CUBE BUILD PROCESS',
                                                     100, 'FILE WATCHER', 101, 'DESTINATION',
                                                     'UNDEFINED'),
                                      o.ctime, o.mtime,
                                      to_char(o.stime, 'YYYY-MM-DD:HH24:MI:SS'),
                                      decode(o.status, 0, 'N/A', 1, 'VALID', 'INVALID'),
                                      decode(bitand(o.flags, 2), 0, 'N', 2, 'Y', 'N'),
                                      decode(bitand(o.flags, 4), 0, 'N', 4, 'Y', 'N'),
                                      decode(bitand(o.flags, 16), 0, 'N', 16, 'Y', 'N'),
                                      o.namespace,
                                      o.defining_edition
                               from sys."_CURRENT_EDITION_OBJ" o
                               where o.owner# = userenv('SCHEMAID')
                                 and o.linkname is null
                                 and (o.type# not in (1  /* INDEX - handled below */,
                                                     10 /* NON-EXISTENT */)
                                      or
                                      (o.type# = 1 and 1 = (select 1
                                                            from sys.ind$ i
                                                           where i.obj# = o.obj#
                                                             and i.type# in (1, 2, 3, 4, 6, 7, 8, 9))))
                                 and o.name != '_NEXT_OBJECT'
                                 and o.name != '_default_auditing_options_'
                                 and bitand(o.flags, 128) = 0
                               union all
                               select l.name, NULL, to_number(null), to_number(null),
                                      'DATABASE LINK',
                                      l.ctime, to_date(null), NULL, 'VALID', 'N', 'N', 'N', NULL, NULL
                               from sys.link$ l
                               where l.owner# = userenv('SCHEMAID')


实现的脚本如下:

sqlplus -s  / as sysdba COL OBJECT_NAME FORMAT A30
COL DB_LINK FORMAT A20
COL OWNER FORMAT A30
COL TABLE_OWNER FORMAT A30
COL TABLE_NAME FORMAT A30
SET LINESIZE 200
SET PAGES 100
SET LONG 999999
prompt object_details
SELECT OWNER,OBJECT_ID,DATA_OBJECT_ID,OBJECT_NAME,OBJECT_TYPE FROM DBA_OBJECTS WHERE OBJECT_NAME=UPPER('$1');

prompt synonym_details
SELECT OWNER,SYNONYM_NAME FROM DBA_SYNONYMS WHERE SYNONYM_NAME=upper('$1');

prompt view_details
SELECT VIEW_NAME,TEXT FROM DBA_VIEWS WHERE VIEW_NAME=upper('$1');

 

EOF
exit

目录
相关文章
|
19天前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
254 9
|
19天前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
103 2
|
4月前
|
Shell
Shell脚本循环控制:shift、continue、break、exit指令
使用这些命令可以让你的Shell脚本像有生命一样动起来。正确使用它们,你的脚本就能像一场精心编排的舞蹈剧目,既有旋律的起伏,也有节奏的跳跃,最终以一场惊艳的表演结束。每一个动作、每一个转折点,都准确、优雅地完成所需要表达的逻辑。如此,你的脚本不只是冰冷的代码,它透过终端的界面,跳着有节奏的舞蹈,走进观众——使用者的心中。
211 60
|
1月前
|
数据采集 监控 Shell
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
Shell脚本利用curl/wget发起请求,结合文本处理工具构建轻量级爬虫,支持并行加速、定时任务、增量抓取及分布式部署。通过随机UA、异常重试等优化提升稳定性,适用于日志监控、价格追踪等场景。相比Python,具备启动快、资源占用低的优势,适合嵌入式或老旧服务器环境,复杂任务可结合Python实现混合编程。
|
7月前
|
关系型数据库 MySQL Shell
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
|
3月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
265 1
|
5月前
|
存储 Unix Shell
确定Shell脚本在操作系统中的具体位置方法。
这对于掌握Linux的文件系统组织结构和路径方面的理解很有帮助,是我们日常工作和学习中都可能使用到的知识。以上讲解详细清晰,应用简便,是每一个想要精通操作系统的计算机爱好者必备的实用技能。
123 17
|
5月前
|
Linux Shell
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
140 4
|
5月前
|
Linux Shell 数据安全/隐私保护
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
286 3
|
6月前
|
Linux Shell
在Linux、CentOS7中设置shell脚本开机自启动服务
以上就是在CentOS 7中设置shell脚本开机自启动服务的全部步骤。希望这个指南能帮助你更好地管理你的Linux系统。
471 25