zoukankan      html  css  js  c++  java
  • Oracle中数据字典的使用方法

    数据字典(Data dictionary)是一种用户可以访问的记录数据库和应用程序元数据的目录。主动数据字典是指在对数据库或应用程序结构进行修改时,其内容可以由DBMS自动更新的数据字典。被动数据字典是指修改时必须手工更新其内容的数据字典。数据库数据字典是一组表和视图结构。它们存放在SYSTEM表空间中。数据库数据字典不仅是每个数据库的中心。而且对每个用户也是非常重要的信息。用户可以用SQL语句访问数据库数据字典。关于数据的信息集合,是一种用户可以访问的记录数据库和应用程序元数据的目录,是对数据库内表信息的物理与逻辑的说明

      ORACLE的数据字典是数据库的重要组成部分之一,它随着数据库的产生而产生, 随着数据库的变化而变化, 体现为sys用户下的一些表和视图。数据字典名称是大写的英文字符。

      数据字典里存有用户信息、用户的权限信息、所有数据对象信息、表的约束条件、统计分析数据库的视图等。我们不能手工修改数据字典里的信息。很多时候,一般的ORACLE用户不知道如何有效地利用它。

          dictionary   全部数据字典表的名称和解释,它有一个同义词dict

      dict_column   全部数据字典表里字段名称和解释

      如果我们想查询跟索引有关的数据字典时,可以用下面这条SQL语句:

    select * from dictionary where instr(comments,'index')>0;

    如果我们想知道user_indexes表各字段名称的详细含义,可以用下面这条SQL语句:

    select column_name,comments from dict_columns where table_name='USER_INDEXES';

    依此类推,就可以轻松知道数据字典的详细名称和解释,不用查看ORACLE的其它文档资料了。

    下面按类别列出一些ORACLE用户常用数据字典的查询使用方法。

    一、用户

      查看当前用户的缺省表空间

    select username,default_tablespace from user_users;

          查看当前用户的角色

    select * from user_role_privs;

          查看当前用户的系统权限和表级权限

    select * from user_sys_privs; 
    select * from user_tab_privs;

    二、表

      查看用户下所有的表

    select * from user_tables;

          查看名称包含log字符的表

    select object_name,object_id from user_objects where instr(object_name,'LOG')>0;

          查看某表的创建时间

    select object_name,created from user_objects where object_name=upper ('&table_name');

          查看某表的大小

    select sum(bytes)/(1024*1024as "size(M)" from user_segments where segment_name=upper('&table_name');

          查看放在ORACLE的内存区里的表

    select table_name,cache from user_tables where instr(cache,'Y')>0;

    三、索引

      查看索引个数和类别

    select index_name,index_type,table_name from user_indexes order by table_name;

          查看索引被索引的字段

    select * from user_ind_columns where index_name=upper('&index_name');

          查看索引的大小 

    select sum(bytes)/(1024*1024as "size(M)" from user_segments where segment_name=upper('&index_name');

    四、序列号

      查看序列号,last_number是当前值

    select * from user_sequences;

    五、视图

      查看视图的名称

    select view_name from user_views;

          查看创建视图的select语句

    select view_name,text_length from user_views; 
    set long 2000;说明:可以根据视图的text_length值设定set long 的大小
    select text from user_views where view_name=upper('&view_name');

    六、同义词

      查看同义词的名称

    select * from user_synonyms;

    七、约束条件

      查看某表的约束条件

    Code

    八、存储函数和过程

      查看函数和过程的状态

    select object_name,status from user_objects where object_type='FUNCTION'
    select object_name,status from user_objects where object_type='PROCEDURE';

          查看函数和过程的源代码

    select text from all_source where owner=user and name=upper('&plsql_name');

    九、触发器

      查看触发器


    set long 50000
      
    set heading off;
      
    set pagesize 2000;
      
    select
      
    'create or replace trigger "' ||
      trigger_name 
    || '"' || chr(10)||
      decode( substr( trigger_type, 
    11 ),
      
    'A''AFTER''B''BEFORE''I''INSTEAD OF' ) ||
      chr(
    10||
      triggering_event 
    || chr(10||
      
    'ON "' || table_owner || '"."' ||
      table_name 
    || '"' || chr(10||
      decode( instr( trigger_type, 
    'EACH ROW' ), 0null,
      
    'FOR EACH ROW' ) || chr(10) ,
  • 相关阅读:
    微信小程序实现课程表实例
    探索Java中的网络编程技术
    Java中的Spring MVC简介笔记
    我没有想赢,我只是不想输
    下次路过,人间再无我。
    从零基础入门MySQL数据库基础课
    vue.js-详解三大流行框架VUE_快速进阶前端大咖-Vue基础
    学习网站/实用工具,收藏的快搜网站,想找什么都有!!!
    【灵魂拷问】你真的懂得Mysql的管理和使用吗?
    【领会要领】web前端-轻量级框架应用(jQuery基础)
  • 原文地址:https://www.cnblogs.com/bingyun84/p/1662609.html
Copyright © 2011-2022 走看看