DangDang0701 发表于 2013-1-15 02:42:08

oracle的系统表

最近用到的系统表挺多的。每次都百度N次。
现记录一下,一劳永逸!哈~~~

1、用户表:
select * from dba_users where username = 'XXX'
修改口令
alter user spgroup identified by spgtest;

2、表空间:
select * from dba_data_files;select * from dba_tablespaces;//表空间select tablespace_name,sum(bytes), sum(blocks)from dba_free_space group by tablespace_name;//空闲表空间select * from dba_data_files where tablespace_name='RBS';//表空间对应的数据文件select * from dba_segments where tablespace_name='INDEXS';

3、数据库对象:
select * from dba_objects;CLUSTER、DATABASE LINK、FUNCTION、INDEX、LIBRARY、PACKAGE、PACKAGE BODY、PROCEDURE、SEQUENCE、SYNONYM、TABLE、TRIGGER、TYPE、UNDEFINED、VIEW。

4、表:
select * from dba_tables;analyze my_table compute statistics;->dba_tables后6列select extent_id,bytes from dba_extentswhere segment_name='CUSTOMERS' and segment_type='TABLE'order by extent_id;//表使用的extent的信息。segment_type='ROLLBACK'查看回滚段的空间分配信息列信息:select distinct table_namefrom user_tab_columnswhere column_name='SO_TYPE_ID';

5、索引:
select * from dba_indexes;//索引,包括主键索引select * from dba_ind_columns;//索引列select i.index_name,i.uniqueness,c.column_namefrom user_indexes i,user_ind_columns cwhere i.index_name=c.index_nameand i.table_name ='ACC_NBR';//联接使用

6、序列:
select * from dba_sequences;

7、视图:
select * from dba_views;select * from all_views;

8、聚簇:
select * from dba_clusters;

9、快照:
select * from dba_snapshots;
快照、分区应存在相应的表空间。

10、同义词:
select * from dba_synonymswhere table_owner='SPGROUP';//if owner is PUBLIC,then the synonyms is a public synonym.if owner is one of users,then the synonyms is a private synonym.

11、数据库链:
select * from dba_db_links;

在spbase下建数据库链
create database link dbl_spnewconnect to spnew identified by spnew using 'jhhx';insert into acc_nbr@dbl_spnewselect * from acc_nbr where nxx_nbr='237' and line_nbr='8888';

12、触发器:
select * from dba_trigers;
存储过程,函数从dba_objects查找。
其文本:
select text from user_source where name='BOOK_SP_EXAMPLE';
建立出错:
select * from user_errors;
oracle总是将存储过程,函数等软件放在SYSTEM表空间。

13、约束:
  (1)约束是和表关联的,可在create table或alter table table_name add/drop/modify来建立、修改、删除约束。
  可以临时禁止约束,如:
alter table book_exampledisable constraint book_example_1;alter table book_exampleenable constraint book_example_1;

    (2)主键和外键被称为表约束,而not null和unique之类的约束被称为列约束。通常将主键和外键作为单独的命名约束放在字段列表下面,而列约束可放在列定义的同一行,这样更具有可读性。
    (3)列约束可从表定义看出,即describe;表约束即主键和外键,可从dba_constraints和dba_cons_columns 查。
select * from user_constraintswhere table_name='BOOK_EXAMPLE';select owner,CONSTRAINT_NAME,TABLE_NAMEfrom user_constraintswhere constraint_type='R'order by table_name;
   (4)定义约束可以无名(系统自动生成约束名)和自己定义约束名(特别是主键、外键)
create table book_example(identifier number not null);create table book_example(identifier number constranit book_example_1 not null);

14、回滚段:
  在所有的修改结果存入磁盘前,回滚段中保持恢复该事务所需的全部信息,必须以数据库发生的事务来相应确定其大小(DML语句才可回滚,create,drop,truncate等DDL不能回滚)。
  回滚段数量=并发事务/4,但不能超过50;使每个回滚段大小足够处理一个完整的事务;
create rollback segment r05tablespace rbs;create rollback segment rbs_cvttablespace rbsstorage(initial 1M next 500k);
  使回滚段在线
alter rollback segment r04 online;
用dba_extents,v$rollback_segs监测回滚段的大小和动态增长。
    回滚段的区间信息
select * from dba_extentswhere segment_type='ROLLBACK' and segment_name='RB1';
   回滚段的段信息,其中bytes显示目前回滚段的字节数
select * from dba_segmentswhere segment_type='ROLLBACK' and segment_name='RB1';
   为事物指定回归段
select * from dba_segmentsset transaction use rollback segment rbs_cvt
   针对bytes可以使用回滚段回缩。
alter rollback segment rbs_cvt shrink;select bytes,extents,max_extents from dba_segmentswhere segment_type='ROLLBACK' and segment_name='RBS_CVT';
   回滚段的当前状态信息:
select * from dba_rollback_segswhere segment_name='RB1';
   比多回滚段状态status,回滚段所属实例instance_num
   查优化值optimal
select n.name,s.optsizefrom v$rollname n,v$rollstat swhere n.usn=s.usn;
   回滚段中的数据
set transaction use rollback segment rb1;/*回滚段名*/select n.name,s.writesfrom v$rollname n,v$rollstat swhere n.usn=s.usn;
  当事务处理完毕,再次查询$rollstat,比较writes(回滚段条目字节数)差值,可确定事务的大小。
  查询回滚段中的事务
column rr heading 'RB Segment' format a18column us heading 'Username' format a15column os heading 'Os User' format a10column te heading 'Terminal' format a10select r.name rr,nvl(s.username,'no transaction') us,s.osuser os,s.terminal tefrom v$lock l,v$session s,v$rollname rwhere l.sid=s.sid(+)and trunc(l.id1/65536)=R.USNand l.type='TX'and l.lmode=6order by r.name;

15、作业
   查询作业信息
select job,broken,next_date,interval,what from user_jobs;select job,broken,next_date,interval,what from dba_jobs;
   查询正在运行的作业
select * from dba_jobs_running;
  使用包exec dbms_job.submit(:v_num,'a;',sysdate,'sysdate + (10/(24*60*60))')加入作业。间隔10秒钟
exec dbms_job.submit(:v_num,'a;',sysdate,'sysdate + (11/(24*60))')加入作业。间隔11分钟使用包exec dbms_job.remove(21)删除21号作业
页: [1]
查看完整版本: oracle的系统表