home *** CD-ROM | disk | FTP | other *** search
/ Liren Large Software Subsidy 5 / 05.iso / a / a523 / 22.ddi / CATALOG5.SQL < prev    next >
Encoding:
Text File  |  1990-06-04  |  46.5 KB  |  1,128 lines

  1. Rem Copyright (c) 1988 by Oracle Corporation
  2. Rem NAME
  3. Rem   CATALOG5.SQL
  4. Rem FUNCTION
  5. Rem   Create V5 catalog views.
  6. Rem NOTES
  7. Rem
  8. Rem   This script must be run while connected to SYS.
  9. Rem
  10. Rem MODIFIED
  11. Rem   Chaudhr    05/31/90 - assorted bug fixes
  12. Rem              - 28120: Add REMARKS & fix WIDTH col's in SYSCOLUMNS_
  13. Rem              - 28121: In SYSTABAUTH & SYSUSERAUTH put ' ' for 'N'
  14. Rem   Chaudhr    01/17/90 - Bug 29307 fix - changed view SYSTABAUTH
  15. Rem   Mendels    03/28/89 - bug 19583: sysindexes_ returns wrong value for seq
  16. Rem   Mendels    11/14/88 - fix bug 16011; create public synonyms
  17. Rem   Mendels    10/25/88 - fix not exists errors
  18. Rem   Bulchan    09/21/88 - Remove '#', ensure statements are < 2048 chars.
  19. Rem   Mendels    09/21/88 - remove public from system synonyms
  20. Rem   Mendels    09/12/88 - remove connect
  21. Rem   Mendels    09/08/88 - bug 15135
  22. Rem   Mendels    08/30/88 - fix bug 14772 (tab view returns indexes)
  23. Rem                         fix bug 9981 (decode type 69 as rowid)
  24. Rem   Peeler     07/26/88 - address compatibility issues
  25. Rem   Wijaya     07/22/88 - merge catsystem.sql
  26. Rem   Wijaya     06/21/88 - add clusters view
  27. Rem   Wijaya     04/27/88 - remove REMARKS and any references to comment$
  28. Rem                         comments are now stored in com$
  29. Rem   Mendels    03/25/88 - do not return dropped tablespaces (and their files)
  30. Rem                         or dropped rollback segments
  31. Rem   Mendels    03/22/88 - Fix audit_actions for v6; 
  32. Rem                         move sequence and constraint views to catalog.sql
  33. Rem   Harmon     03/22/88 - add sequence views
  34. rem Chris   22-mar-88 added sequence catalogs
  35. rem Mendels 15-Mar-88  Rename to catalog5.sql
  36. rem Hong    Revised 02-Mar-88  new undo status
  37. rem Wijaya  Revised 16-Feb-88  new dictionary table icol$
  38. rem Hong    Revised 01-Feb-88  Fix sysfiles to use actual file names and
  39. rem                            not to display invalid file entries
  40. rem Wijaya  Revised 20-Jan-88  Add views for constraints
  41. rem Wijaya  Revised 04-Dec-87  Add REMARKS column to view TAB
  42. rem Wijaya  Revised 20-Nov-87  Add views and synonyms for fixed tables
  43. rem Mendels Revised 05-Nov-87  Make sysfiles an outer-join.
  44. rem Wijaya  Revised 13-Oct-87  undo the fix below, because the bug is in cri.c
  45. rem Hong    Revised 13-Oct-87  fix sysindexes to consider cluster indexes with
  46. rem                   no entries in col$
  47. rem Wijaya  Revised 12-Oct-87  add VARCHAR consideration
  48. rem Hong    Revised 27-Aug-87  pctfree/pctused moved to tab$, clu$
  49. rem Hong    Revised 09-Aug-87  decode column types in 'col'
  50. rem Hong    Revised 05-Aug-87  add view 'freespace'
  51. rem Hong    Revised 27-Jul-87  modify view 'tabspaces' to consider users with
  52. rem                   resource priv has access to ALL tablespaces
  53. rem Hong    Revised 16-Jun-87  create views with names ended in underscore
  54. rem                   (e.g. syscatalog_). These views return user id
  55. rem                   and make views created using them more efficient
  56. rem Hong    Revised 10-Jun-87  dictionary updates
  57. rem Hong    Revised 15-Apr-87  audit$ moved from sys.obj$ to sys.tab$,sys.view$
  58. rem Hong    Revised 04-Apr-87  Add sysfiles, modify systaballoc, storage,
  59. rem                   (sys)extents, syscolumns, syscatalog,
  60. rem                   (sys)indexes, (sys)tabspacesb
  61. rem Hong    Revised 26-Mar-87  Rewrite for version 6 dict. 
  62. rem                   Combine catalog.ora and newcat.ora
  63. rem                   Remove spaces, partitions, progs, exptab, expvew
  64. rem                   Add tablespaces, tsquotas, undoseg, database
  65. rem Andy    Revised 24-Sept-86 Modify views synonyms, privatesyn, and publicsyn
  66. rem                   to show synonyms for non-existent, local tables
  67. rem Andy    Revised 17-Sept-86 Modify views synonyms, privatesyn, and 
  68. rem                   publicsyn to show synonyms for remote tables
  69. rem Derry   Revised 29-Jul-86  Create views for DBLINKS table, 5.2.
  70. rem Andy    Revised 25-Oct-85  Make view partitions an outer join.
  71. rem Andy    Revised 09-Oct-85  Replace sytemaudit, defaultaudit, and 
  72. rem                            systabaudit with SYSTEM_AUDIT, DEFAULT_AUDIT,
  73. rem                            and TABLE_AUDIT.  Added AUDIT_DBA, AUDIT_EXISTS,
  74. rem                            AUDIT_CONNECT, AUDIT_ACCESS.
  75. rem                            Deleted views syssessions and sysaudit_trail.
  76. rem                            Made sessions a synonym for audit_connect.
  77. rem Andy    Revised 15-Jul-85  Change ren$newname to new$name.
  78. rem Derry   Revised 11-Jun-85  Add views CLUSTERS and CLUSTERCOLUMNS.
  79. rem Andy    Revised 06-Jun-85  Add remarks columns to syscatalog, catalog,
  80. rem                            syscolumns, columns, col.  
  81. rem                            Add defaultval column to syscolumns, columns,
  82. rem                            and col.
  83. rem                            Add views and tables for auditing: defaultaudit,
  84. rem                            systemaudit, systabaudit, audit_actions,
  85. rem                            syssessions, sessions, sysaudit_trail, and
  86. rem                            audit_trail.
  87. rem Derry   Revised 24-May-85  Removed SESSIONS since SYS.SESSIONS no longer
  88. rem                   exists (AUDIT_TRAIL views needed).
  89. rem Andy    Revised 08-Feb-85  Qualify column references.
  90. rem                            Rewrite views SYNONYMS, PUBSYN, and PRIVSYN
  91. rem                            for correctness.
  92. rem                            Rewrite views CATALOG, SYSCATALOG, VIEWS,
  93. rem                            and SYSVIEWS for speed.
  94. rem                            Move views back to SYSTEM from SYS.
  95. rem                            Delete views IDX and COLIDX, since view INDEXES
  96. rem                            provides similar information efficiently.
  97. rem                            Rename PRIVSYN to PRIVATESYN and PUBSYN to
  98. rem                            PUBLICSYN.
  99. rem                            Add SET WORKSIZE 16
  100. rem Andy    Revised 26-Nov-84  Convert queries to use EXISTS
  101. rem Miner   Revised 13-Nov-84  Rewrite for new dictionary but it still
  102. rem                   looks much the same to users
  103. rem Dana    Revised 20-Jul-84  Rewrite for speed.  drop views before creating.
  104. rem                   Added COLIDX,IDX,PRIVSYN,PUBSYN,SYNONYMS.
  105. rem                   Renamed DEPENDENCIES to XREF.
  106. rem Dana    Revised 03-Jun-84  update for new V4 dictionary info
  107. rem Dana    Revised 23-May-84  fixed STORAGE not to return all users
  108. rem Clare   Revised 10-May-84  added SYSUSERLIST to DTAB:
  109. rem Clare   Revised 10-May-84  added SYSPROGS:
  110. rem Dana    Revised 23-Apr-84  for V4
  111. rem Weiss   Created 03-Feb-83
  112. rem 
  113. drop table dual;
  114. create table dual(dummy char(1));
  115. insert into dual values( 'X' );
  116. commit;
  117. grant select on dual to public;
  118. rem
  119. rem there may be no index on a table, therefore need outerjoin
  120. rem there may be more than one indexes, therefore need to max(d.xxxxxx)
  121. rem
  122. drop view systaballoc_;
  123. create view systaballoc_ ( creator, creatorid, tname, d_blks, d_exts, i_blks, 
  124.                i_exts ) as
  125.   select
  126.     u.name, o.owner#, o.name, d.blocks, d.extents, i.blocks, i.extents
  127.   from sys.user$ u, sys.obj$ o, sys.tab$ t, sys.ind$ x, sys.seg$ d, sys.seg$ i
  128.   where t.obj# = o.obj#
  129.     and o.owner# = u.user#
  130.     and t.file# = d.file# 
  131.     and t.block# = d.block#
  132.     and x.bo# (+) = t.obj#
  133.     and x.file# = i.file# (+)
  134.     and x.block# = i.block# (+)
  135. /
  136. drop view systaballoc;
  137. create view systaballoc ( creator, tname, d_blks, d_exts, i_blks, i_exts ) as
  138.   select creator, tname, max(d_blks), max(d_exts), sum(i_blks), sum(i_exts)
  139.   from systaballoc_
  140.   group by creator, tname
  141. /
  142. drop view taballoc;
  143. create view taballoc ( tname, d_blks, d_exts, i_blks, i_exts ) as
  144.   select tname, max(d_blks), max(d_exts), sum(i_blks), sum(i_exts)
  145.   from systaballoc_
  146.   where  creatorid = uid
  147.   group by tname
  148. /   
  149. grant select on taballoc to public;
  150. rem
  151. rem group all objects which occupies storage: tables, clusters, indexes
  152. rem
  153. drop view syssegobj;
  154. create view syssegobj (obj#, file#, block#, type, pctfree$, pctused$) as
  155.   select obj#, file#, block#, 'TABLE', pctfree$, pctused$ from sys.tab$
  156.   union
  157.   select obj#, file#, block#, 'CLUSTER', pctfree$, pctused$ from sys.clu$
  158.   union 
  159.   select obj#, file#, block#, 'INDEX', to_number(null), to_number(null)
  160.          from sys.ind$
  161. /
  162. drop view sysstorage_;
  163. create view sysstorage_ (creator, creatorid, name, type, storage, extents) as
  164.   select u.name, o.owner#, o.name, so.type, s.blocks, s.extents
  165.   from  sys.user$ u, sys.seg$ s, sys.obj$ o, syssegobj so
  166.   where u.user# = o.owner#
  167.     and o.obj# = so.obj#
  168.     and s.file# = so.file#
  169.     and s.block# = so.block# 
  170. /
  171. drop view sysstorage;
  172. create view sysstorage (creator, name, type, storage, extents) as
  173.   select creator, name, type, sum(storage), sum(extents)
  174.   from sysstorage_
  175.   group by creator, name, type
  176. /
  177. drop view freespace;
  178. create view freespace (tablespace, fileno, starting, length) as
  179.   select ts.name, f.file#, f.block#, f.length
  180.   from sys.ts$ ts, sys.fet$ f
  181.   where f.ts# = ts.ts#
  182. /
  183. drop view storage;
  184. create view storage(name, type, storage, extents) as
  185.   select name, type, sum(storage), sum(extents)
  186.   from  sysstorage_
  187.   where creatorid = uid
  188.   group by name, type
  189. grant select on storage to public;
  190. drop view sysextents_;
  191. create view sysextents_ (creator, creatorid, name, type,  storage, starting, 
  192.              ending) as
  193.   select u.name, o.owner#, o.name, so.type, e.length, e.block#, 
  194.      e.block#+e.length-1
  195.   from sys.uet$ e, sys.seg$ s, sys.user$ u, sys.obj$ o, syssegobj so
  196.   where e.segfile# = s.file#
  197.     and e.segblock# = s.block#
  198.     and s.user# = u.user#
  199.     and e.segfile# = so.file#
  200.     and e.segblock# = so.block#
  201.     and so.obj# = o.obj#
  202. /
  203. drop view sysextents;
  204. create view sysextents(creator, name, which, storage, starting, ending) as
  205.   select creator, name, type, storage, starting, ending
  206.   from sysextents_
  207. /
  208. drop view extents;
  209. create view extents(name, which, storage, starting, ending) as
  210.   select name, type, storage, starting, ending
  211.   from sysextents_
  212.   where creatorid = uid
  213. /
  214. grant select on extents to public;
  215. drop view syscolumns_;
  216. create view syscolumns_ (cname, tname, creator, creatorid, colno, coltype,
  217.             width, scale, precision, nulls, defaultval, remarks) as
  218.   select  c.name, t.name, u.name, t.owner#, c.col#, 
  219.       decode(c.type#, 1, 'CHAR', 2, 'NUMBER', 8, 'LONG', 9, 'VARCHAR',
  220.                           12, 'DATE', 23, 'RAW', 24, 'LONG RAW',
  221.                           69, 'ROWID', 'UNDEFINED'),
  222.       decode(c.type#, 2, c.precision, c.length),
  223.       c.scale, c.precision,
  224.           decode(c.null$, 0, 'NULL', 'NOT NULL'), c.default$, co.comment$
  225.   from    sys.user$ u, sys.col$ c, sys.obj$ t, sys.com$ co
  226.   where t.type in (2, 4)
  227.     and t.obj# = c.obj#
  228.     and c.obj# = co.obj# (+)
  229.     and c.col# = co.col# (+)
  230.     and    u.user# = t.owner#
  231.     and ( t.owner# = uid
  232.         or exists
  233.       ( select null
  234.         from  sys.tabauth$ tau
  235.         where t.obj# = tau.obj#
  236.           and tau.grantee# in (uid, 1)
  237.           )
  238.         )
  239. /
  240. drop view syscolumns;
  241. create view syscolumns (cname, tname, creator, colno, coltype,
  242.             width, scale, precision, nulls, defaultval, remarks) as
  243.   select cname, tname, creator, colno, coltype, width, scale, precision,
  244.          nulls, defaultval, remarks
  245.   from  syscolumns_
  246. /
  247. grant select on syscolumns to public;
  248. drop view columns;
  249. create view columns (cname, tname, creator, colno, coltype,
  250.              width, scale, precision, nulls, defaultval, remarks) as
  251.   select cname, tname, creator, colno, coltype, width, scale, precision,
  252.          nulls, defaultval, remarks
  253.   from  syscolumns_
  254.   where creatorid not in (0,1)
  255. /
  256. grant select on columns to public;
  257. drop view syscatalog_;
  258. create view syscatalog_ (tname, creator, creatorid, tabletype)
  259.   as
  260.   select o.name, u.name, o.owner#,
  261.          decode(o.type, 2, 'TABLE', 4, 'VIEW', 6, 'SEQUENCE','?')
  262.   from    sys.user$ u, sys.obj$ o
  263.   where u.user# = o.owner#
  264.     and    o.type in (2, 4, 6)
  265.     and ( o.owner# = uid
  266.         or o.obj# in
  267.            (select tau.obj#
  268.         from   sys.tabauth$ tau
  269.         where  tau.grantee# in (uid, 1)
  270.             )
  271.     )
  272. /
  273. drop view syscatalog;
  274. create view syscatalog (tname, creator, tabletype) as
  275.   select tname, creator, tabletype
  276.   from syscatalog_
  277. /
  278. grant select on syscatalog to public;
  279. rem
  280. rem The catalog view returns almost all tables accessible to the user
  281. rem except tables in SYS and SYSTEM ("dictionary tables").
  282. rem 
  283. drop view catalog;
  284. create view catalog (tname, creator, tabletype) as
  285.   select tname, creator, tabletype
  286.   from    syscatalog_
  287.   where creatorid not in (0,2)
  288. /
  289. grant select on catalog to public;
  290. drop view sysindexes_;
  291. create view sysindexes_ (iname, icreator, icreatorid, tname, ttype, creator, 
  292.             creatorid, colnames, indextype, compression, seq)  as
  293.   select  oi.name, ui.name, oi.owner#, ot.name, 
  294.       decode(ot.type, 2, 'TABLE', 3, 'CLUSTER', 'UNDEFINED'),
  295.       ut.name, ot.owner#, c.name,
  296.       decode(i.unique$, 1, 'UNIQUE', 'NON UNIQUE'), 
  297.       decode(i.compress$, 1, 'COMPRESS', 'NOCOMPRESS'), ic.pos#
  298.   from sys.user$ ui, sys.user$ ut, sys.ind$ i, sys.obj$ oi, sys.obj$ ot,
  299.        sys.icol$ ic, sys.col$ c
  300.   where i.obj# = oi.obj#
  301.     and i.bo# = ot.obj#
  302.     and i.obj# = ic.obj#
  303.     and ic.col# = c.col#
  304.     and c.obj# = i.bo#
  305.     and    oi.owner# = ui.user#
  306.     and    ot.owner# = ut.user#
  307.     and ot.type in (2, 3)
  308.     and (ot.owner# = uid
  309.          or oi.owner# = uid
  310.          or exists
  311.        (select null
  312.         from   sys.tabauth$ tau
  313.         where  ot.obj# = tau.obj#
  314.         and       tau.grantee# in (uid, 1)
  315.            )
  316.         )
  317. /
  318. drop view sysindexes;
  319. create view sysindexes (iname, icreator, tname, ttype, creator, colnames,
  320.              indextype, compression, seq) as
  321.   select iname, icreator, tname, ttype, creator, colnames, 
  322.      indextype, compression, seq
  323.   from  sysindexes_
  324. /
  325. grant select on sysindexes to public;
  326. drop view indexes;
  327. create view indexes (iname, icreator, tname, ttype, creator, colnames,
  328.              indextype, compression, seq) as
  329.   select iname, icreator, tname, ttype, creator, colnames, 
  330.      indextype, compression, seq
  331.   from  sysindexes_
  332.   where    icreatorid = uid
  333.      or creatorid = uid
  334. /
  335. grant select on indexes to public;
  336. drop view clusters;
  337. create view clusters (clcreator, clname, tcreator, tname)
  338. as select cu.name, c.name, tu.name, t.name
  339. from sys.user$ tu, sys.user$ cu, sys.obj$ t, sys.obj$ c, sys.tab$ tab
  340. where c.type = 3
  341.   and t.type = 2
  342.   and t.obj# = tab.obj#
  343.   and tab.clu# = c.obj#
  344.   and c.owner# = cu.user#
  345.   and t.owner# = tu.user#
  346.   and (t.owner# = uid
  347.        or c.owner# = uid
  348.        or exists
  349.           (select null
  350.            from sys.tabauth$ tau
  351.            where t.obj# = tau.obj#
  352.              and tau.grantee# in (uid, 1)
  353.           )
  354.       )
  355. /
  356. grant select on clusters to public;
  357. drop view clustercolumns;
  358. create view clustercolumns (clcreator, clname, clcol, tcreator, tname, tcol) as
  359.   select cu.name, c.name, cc.name, tu.name, t.name, tc.name
  360.   from   sys.col$ tc, sys.col$ cc, sys.user$ tu, sys.user$ cu,
  361.          sys.obj$ t,  sys.obj$ c, sys.tab$ tab
  362.   where c.type = 3 and t.type = 2
  363.     and    t.obj# = tab.obj#  and tab.clu# = c.obj#
  364.     and    c.obj# = cc.obj#   and t.obj# = tc.obj#
  365.     and    cc.segcol# = tc.segcol#
  366.     and c.owner# = cu.user# and t.owner# = tu.user#
  367.     and (t.owner# = uid or c.owner# = uid
  368.          or  exists
  369.             (select null
  370.              from sys.tabauth$ tau
  371.              where t.obj# = tau.obj#
  372.                and tau.grantee# in (uid, 1)
  373.             )
  374.          )
  375. /
  376. grant select on clustercolumns to public;
  377.  
  378. drop view views;
  379. create view views( viewname, viewtext) as
  380.     select o.name, v.text
  381.     from  sys.view$ v, sys.obj$ o
  382.     where v.obj# = o.obj#
  383.           and o.owner# = uid
  384. /
  385. grant select on views to public;
  386. drop view sysviews;
  387. create view sysviews (viewname, vcreator) as
  388.   select tname, creator
  389.   from  syscatalog
  390.   where tabletype = 'VIEW'
  391. /
  392. grant select on sysviews to public;
  393. drop view systabauth;
  394. create view systabauth (grantor, grantee, creator, tname, timestamp,
  395.                 alt, del, ndx, ins, sel, upd, ref) as
  396.   select ur.name, ue.name, u.name, o.name, tau.time, 
  397.          decode(tau.alter$,  0, ' ', 2, 'Y', 'G'), 
  398.          decode(tau.delete$, 0, ' ', 2, 'Y', 'G'), 
  399.          decode(tau.index$,  0, ' ', 2, 'Y', 'G'), 
  400.          decode(tau.insert$, 0, ' ', 2, 'Y', 'G'), 
  401.          decode(tau.select$, 0, ' ', 2, 'Y', 'G'), 
  402.          decode(tau.update$, 0, ' ', 1, 'R',  2, 'Y', 'G'),
  403.          decode(tau.references$, 0, ' ', 1, 'R',  2, 'Y', 'G')
  404.   from sys.tabauth$ tau, sys.obj$ o, sys.user$ u, sys.user$ ur, sys.user$ ue
  405.   where tau.obj# = o.obj#
  406.     and o.owner# = u.user#
  407.     and tau.grantor# = ur.user#
  408.     and tau.grantee# = ue.user#
  409.     and (tau.grantor# = uid or tau.grantee# in (uid, 1))
  410.   union
  411.   select u.name, u.name , u.name, o.name, o.ctime,
  412.          'G','G','G','G','G','G','G'
  413.   from user$ u, obj$ o
  414.   where u.user# = uid and o.owner# = uid  
  415. /
  416. grant select on systabauth to public;
  417. drop view syscolauth;
  418. create view syscolauth (grantor, grantee, creator, tname, timestamp, 
  419.                 colname, upd, ref) as
  420.   select ur.name, ue.name, u.name, o.name, c.time, c.name, 
  421.      decode(c.update$, 2, 'Y', 'G'), decode(c.references$, 2, 'Y', 'G')
  422.   from  sys.colauth$ c, sys.obj$ o, sys.user$ u, sys.user$ ur, sys.user$ ue
  423.   where c.obj# = o.obj#
  424.     and o.owner# = u.user#
  425.     and c.grantor# = ur.user#
  426.     and c.grantee# = ue.user#
  427.     and (c.grantor# = uid or c.grantee# in (uid, 1))
  428. /
  429. grant select on syscolauth to public;
  430. drop view sysuserauth;
  431. create view sysuserauth (userid, username, password, timestamp, connectauth, 
  432.                  dbaauth, resourceauth, tablespace, tempspace) as 
  433.   select u.user#, u.name, u.password, u.ctime, decode(u.connect$, 1, 'Y', ' '),
  434.      decode(u.dba$, 1, 'Y', ' '), decode(u.resource$, 1, 'Y', ' '), 
  435.      ts.name, tmp.name
  436.   from  sys.user$ u, sys.ts$ ts, sys.ts$ tmp
  437.   where u.datats# = ts.ts# 
  438.     and u.tempts# = tmp.ts#
  439. /
  440. drop view sysuserlist;
  441. create view sysuserlist (userid, username, timestamp, connectauth, dbaauth, 
  442.              resourceauth, tablespace, tempspace) as
  443.    select userid, username, timestamp, connectauth, dbaauth,
  444.       resourceauth, tablespace, tempspace
  445.    from  sysuserauth
  446. /
  447. grant select on sysuserlist to public;
  448. rem
  449. rem    The first two unioned query-expressions in the SYNONYMS view
  450. rem    could be combined into a single query-expression with the
  451. rem    term "tab$owner in (1,uid)."  This was not done because the
  452. rem    optimizer will not do or-optimization in the presence of
  453. rem    outer joins; this forces the access path selector to perform
  454. rem    a time-consuming, full-table scan of sys.tables s.
  455. rem
  456. drop view synonyms;
  457. create view synonyms (sname, syntype, creator, tname, database, tabtype) as
  458.   select s.name, 
  459.      decode (s.owner#,1,'PUBLIC','PRIVATE'), t.owner, t.name, 'LOCAL', 
  460.      decode(ot.type, 1, 'INDEX', 2, 'TABLE', 3, 'CLUSTER', 4, 'VIEW',
  461.              5, 'SYNONYM', 6, 'SEQUENCE', 'UNDEFINED')
  462.   from  sys.obj$ s, sys.obj$ ot, sys.syn$ t, sys.user$ u
  463.   where s.obj# = t.obj#
  464.     and s.type = 5
  465.     and ot.name = t.name
  466.     and t.owner = u.name
  467.     and ot.owner# = u.user#
  468.     and s.owner# in (1,uid)
  469.     and t.node is null
  470. union
  471.   select s.name, decode(s.owner#, 1, 'PUBLIC', 'PRIVATE'),
  472.      t.owner, t.name, t.node, 'REMOTE'
  473.   from  sys.obj$ s, sys.syn$ t
  474.   where s.obj# = t.obj#
  475.     and s.type = 5
  476.     and s.owner# in (1, uid)
  477.     and t.node is not null
  478. /  
  479. grant select on synonyms to public;
  480. drop view publicsyn;
  481. create view publicsyn (sname, creator, tname, database, tabtype) as
  482.   select sname, creator, tname, database, tabtype
  483.   from  synonyms
  484.   where syntype = 'PUBLIC'
  485. /
  486. grant select on publicsyn to public;
  487. drop view privatesyn;
  488. create view privatesyn (sname, creator, tname, database, tabtype) as
  489.   select sname, creator, tname, database, tabtype
  490.   from  synonyms
  491.   where syntype = 'PRIVATE'
  492. /
  493. grant select on privatesyn to public;
  494. drop view tab;
  495. create view tab (tname, tabtype, clusterid) as
  496.    select o.name,
  497.       decode(o.type, 2, 'TABLE', 3, 'CLUSTER', 
  498.              4, 'VIEW', 5, 'SYNONYM'), t.tab#
  499.   from  sys.tab$ t, sys.obj$ o
  500.    where o.owner# = uid and o.type >= 2 and o.type <=5
  501.      and o.obj# = t.obj# (+)
  502. /
  503. grant select on tab to public;
  504. drop view col;
  505. create view col (tname, colno, cname, coltype, width, scale, precision, nulls,
  506.                  defaultval, remarks) as
  507.   select t.name, c.col#, c.name, 
  508.      decode(c.type#, 1, 'CHAR', 2, 'NUMBER', 8, 'LONG', 9, 'VARCHAR',
  509.                          12, 'DATE', 23, 'RAW', 24, 'LONG RAW',
  510.                          69, 'ROWID', 'UNDEFINED'),
  511.          decode(c.type#, 2, c.precision, c.length), 
  512.      c.scale, c.precision,
  513.      decode(c.null$, 0, 'NULL', 'NOT NULL'), c.default$, co.comment$
  514.    from  sys.col$ c, sys.obj$ t, sys.com$ co
  515.    where t.obj# = c.obj#
  516.    and   c.obj# = co.obj# (+)
  517.    and   c.col# = co.col# (+)
  518.    and     t.type in (2, 3, 4)
  519.    and     t.owner# = uid
  520. /
  521. grant select on col to public;
  522. drop view tabquotas;
  523. create view tabquotas (tname, type, objno, nextext, maxext, pinc,
  524.                pfree, pused) as
  525.   select t.name, so.type, t.obj#, s.extsize, s.maxexts, s.extpct, so.pctfree$,
  526.      so.pctused$
  527.   from  sys.seg$ s, sys.obj$ t, syssegobj so
  528.   where t.owner# = uid
  529.     and t.obj# = so.obj#
  530.     and so.file# = s.file# 
  531.     and so.block# = s.block#
  532. /
  533. grant select on tabquotas to public;
  534. rem   
  535. rem SYSTEM_AUDIT gives one row with the system auditing options.
  536. rem The table is only accessible to dba's.
  537. rem
  538. drop view SYSTEM_AUDIT;
  539. create view SYSTEM_AUDIT (connect$,dba$,not_exists$,resource$) as
  540. select substr(t.audit$,1,1) || '/' || substr(t.audit$,2,1),
  541.        substr(t.audit$,3,1) || '/' || substr(t.audit$,4,1),
  542.        substr(t.audit$,5,1) || '/' || substr(t.audit$,6,1),
  543.        substr(t.audit$,7,1) || '/' || substr(t.audit$,8,1)
  544. from    sys.obj$ o, sys.tab$ t
  545. where o.owner# = 0 
  546.   and o.name = '_system_auditing_options_'
  547.   and o.obj# = t.obj#
  548. /
  549. rem
  550. rem DEFAULT_AUDIT gives one row with the default table auditing options.
  551. rem The table is accessible to public.
  552. rem
  553. drop view DEFAULT_AUDIT;
  554. create view DEFAULT_AUDIT (alt,aud,com,del,gra,ind,ins,loc,ren,sel,upd) as
  555. select
  556.     substr(audit$,1,1) || '/' || substr(audit$,2,1),
  557.     substr(audit$,3,1) || '/' || substr(audit$,4,1),
  558.     substr(audit$,5,1) || '/' || substr(audit$,6,1),
  559.     substr(audit$,7,1) || '/' || substr(audit$,7,1),
  560.     substr(audit$,9,1) || '/' || substr(audit$,10,1),
  561.     substr(audit$,11,1) || '/' || substr(audit$,12,1),
  562.     substr(audit$,13,1) || '/' || substr(audit$,14,1),
  563.     substr(audit$,15,1) || '/' || substr(audit$,16,1),
  564.     substr(audit$,17,1) || '/' || substr(audit$,18,1),
  565.     substr(audit$,19,1) || '/' || substr(audit$,20,1),
  566.     substr(audit$,21,1) || '/' || substr(audit$,22,1)
  567. from  sys.obj$ o, sys.tab$ t
  568. where o.owner# = 0 
  569.   and o.name = '_default_auditing_options_'
  570.   and t.obj# = o.obj#
  571. /
  572. grant select on DEFAULT_AUDIT to public;
  573. rem
  574. rem TABLE_AUDIT lists auditing options for the user's own tables
  575. rem and views, or for all tables and views if a DBA.
  576. rem
  577. drop view TABLE_AUDIT;
  578. create view TABLE_AUDIT (creator, tname, tabletype, alt,aud,com,del,gra,ind,ins,loc,ren,sel,upd) as
  579.   select u.name, o.name, 'TABLE',
  580.    substr(t.audit$,1,1) || '/' || substr(t.audit$,2,1),
  581.    substr(t.audit$,3,1) || '/' || substr(t.audit$,4,1),
  582.    substr(t.audit$,5,1) || '/' || substr(t.audit$,6,1),
  583.    substr(t.audit$,7,1) || '/' || substr(t.audit$,8,1),
  584.    substr(t.audit$,9,1) || '/' || substr(t.audit$,10,1),
  585.    substr(t.audit$,11,1) || '/' || substr(t.audit$,12,1),
  586.    substr(t.audit$,13,1) || '/' || substr(t.audit$,14,1),
  587.    substr(t.audit$,15,1) || '/' || substr(t.audit$,16,1),
  588.    substr(t.audit$,17,1) || '/' || substr(t.audit$,18,1),
  589.    substr(t.audit$,19,1) || '/' || substr(t.audit$,20,1),
  590.    substr(t.audit$,21,1) || '/' || substr(t.audit$,22,1)
  591.     from sys.obj$ o, sys.user$ u, sys.tab$ t
  592.     where o.type = 2 and o.name != '_default_auditing_options_'
  593.      and o.name != '_system_auditing_options_' and o.owner# = u.user#
  594.      and o.obj# = t.obj# and (o.owner# = uid or exists  (select null from sys.user$ where user# = uid and dba$ = 1))
  595.   union
  596.   select u.name, o.name, 'VIEW',
  597.     substr(t.audit$,1,1) || '/' || substr(t.audit$,2,1),
  598.     substr(t.audit$,3,1) || '/' || substr(t.audit$,4,1),
  599.     substr(t.audit$,5,1) || '/' || substr(t.audit$,6,1),
  600.     substr(t.audit$,7,1) || '/' || substr(t.audit$,8,1),
  601.     substr(t.audit$,9,1) || '/' || substr(t.audit$,10,1),
  602.     substr(t.audit$,11,1) || '/' || substr(t.audit$,12,1),
  603.     substr(t.audit$,13,1) || '/' || substr(t.audit$,14,1),
  604.     substr(t.audit$,15,1) || '/' || substr(t.audit$,16,1),
  605.     substr(t.audit$,17,1) || '/' || substr(t.audit$,18,1),
  606.     substr(t.audit$,19,1) || '/' || substr(t.audit$,20,1),
  607.     substr(t.audit$,21,1) || '/' || substr(t.audit$,22,1)
  608.     from sys.obj$ o, sys.user$ u, sys.view$ t
  609.     where o.type = 4 and o.name != '_default_auditing_options_'
  610.      and o.name != '_system_auditing_options_' 
  611.      and o.owner# = u.user# and o.obj# = t.obj#
  612.      and (o.owner# = uid or exists (select null from sys.user$  where user# = uid and dba$ = 1))
  613. /
  614. grant select on TABLE_AUDIT to public;
  615. rem
  616. rem audit_actions maps an action number to the action name.
  617. rem The table is accessible to public.
  618. rem
  619. drop table audit_actions;
  620. create table audit_actions(
  621.   action number not null, name char(27) not null
  622. );
  623. grant select on audit_actions to public;
  624. insert into audit_actions values (0, 'UNKNOWN');
  625. insert into audit_actions values (1, 'CREATE TABLE');
  626. insert into audit_actions values (2, 'INSERT');
  627. insert into audit_actions values (3, 'SELECT');
  628. insert into audit_actions values (4, 'CREATE CLUSTER');
  629. insert into audit_actions values (5, 'ALTER CLUSTER');
  630. insert into audit_actions values (6, 'UPDATE');
  631. insert into audit_actions values (7, 'DELETE');
  632. insert into audit_actions values (8, 'DROP CLUSTER');
  633. insert into audit_actions values (9, 'CREATE INDEX');
  634. insert into audit_actions values (10, 'DROP INDEX');
  635. insert into audit_actions values (11, 'ALTER INDEX');
  636. insert into audit_actions values (12, 'DROP TABLE');
  637. insert into audit_actions values (13, 'CREATE SEQUENCE');
  638. insert into audit_actions values (14, 'ALTER SEQUENCE');
  639. insert into audit_actions values (15, 'ALTER TABLE');
  640. insert into audit_actions values (16, 'DROP SEQUENCE');
  641. insert into audit_actions values (17, 'GRANT OBJECT');
  642. insert into audit_actions values (18, 'REVOKE OBJECT');
  643. insert into audit_actions values (19, 'CREATE SYNONYM');
  644. insert into audit_actions values (20, 'DROP SYNONYM');
  645. insert into audit_actions values (21, 'CREATE VIEW');
  646. insert into audit_actions values (22, 'DROP VIEW');
  647. insert into audit_actions values (23, 'VALIDATE INDEX');
  648. insert into audit_actions values (26, 'LOCK');
  649. insert into audit_actions values (27, 'UNDEFINED');
  650. insert into audit_actions values (28, 'RENAME');
  651. insert into audit_actions values (29, 'COMMENT');
  652. insert into audit_actions values (30, 'AUDIT OBJECT');
  653. insert into audit_actions values (31, 'NOAUDIT OBJECT');
  654. insert into audit_actions values (32, 'CREATE DATABASE LINK');
  655. insert into audit_actions values (33, 'DROP DATABASE LINK');
  656. insert into audit_actions values (34, 'CREATE DATABASE');
  657. insert into audit_actions values (35, 'ALTER DATABASE');
  658. insert into audit_actions values (36, 'CREATE ROLLBACK SEG');
  659. insert into audit_actions values (37, 'ALTER ROLLBACK SEG');
  660. insert into audit_actions values (38, 'DROP ROLLBACK SEG');
  661. insert into audit_actions values (39, 'CREATE TABLESPACE');
  662. insert into audit_actions values (40, 'ALTER TABLESPACE');
  663. insert into audit_actions values (41, 'DROP TABLESPACE');
  664. insert into audit_actions values (42, 'ALTER SESSION');
  665. insert into audit_actions values (43, 'ALTER USER');
  666. insert into audit_actions values (49, 'ALTER SYSTEM');
  667. insert into audit_actions values (60, 'LOGON');
  668. insert into audit_actions values (61, 'LOGOFF');
  669. insert into audit_actions values (62, 'CLEANUP');
  670. insert into audit_actions values (63, 'SESSION');
  671. insert into audit_actions values (64, 'AUDIT SYSTEM');
  672. insert into audit_actions values (65, 'NOAUDIT SYSTEM');
  673. insert into audit_actions values (66, 'AUDIT DEFAULT');
  674. insert into audit_actions values (67, 'NOAUDIT DEFAULT');
  675. insert into audit_actions values (68, 'GRANT SYSTEM');
  676. insert into audit_actions values (69, 'REVOKE SYSTEM');
  677. insert into audit_actions values (70, 'CREATE PUBLIC SYNONYM');
  678. insert into audit_actions values (71, 'DROP PUBLIC SYNONYM');
  679. insert into audit_actions values (72, 'CREATE PUBLIC DATABASE LINK');
  680. insert into audit_actions values (73, 'DROP PUBLIC DATABASE LINK');
  681. insert into audit_actions values (80, 'USER COMMENT');
  682. commit;
  683. create unique index audact$uid on audit_actions(action,name) nocompress;
  684.  
  685. rem
  686. rem    AUDIT_TRAIL:  Lists audit trail entries on the user's objects
  687. rem                  or other pertinent entries.
  688. rem                  DBA sees all.
  689. rem
  690. drop view audit_trail;
  691. create view audit_trail as 
  692.   select userid, userhost, terminal, timestamp, obj$creator, obj$name,
  693.          t.action action, act.name action_name, new$name,
  694.          auth$privileges, auth$grantee, ses$actions,
  695.          logoff$time, logoff$lread, logoff$pread, logoff$lwrite, logoff$dead,
  696.          comment$text, sessionid, entryid, statement, returncode
  697.   from sys.aud$ t, audit_actions act
  698.   where t.action = act.action
  699.     and (t.obj$creator = user 
  700.          or (t.obj$creator is null and t.userid = user)
  701.          or exists
  702.             (select null from sys.user$
  703.                   where user# = uid and dba$ = 1)
  704.          )
  705. /
  706. grant select on audit_trail to public;
  707.  
  708. rem
  709. rem    AUDIT_DBA:  Lists audit trail entries produced by AUDIT DBA
  710. rem                (all operations with an action code of 24, 25, or
  711. rem                64 through 73).
  712. rem                This view is accessible to DBAs only.
  713. rem
  714. drop view AUDIT_DBA;
  715. create view AUDIT_DBA as  
  716.   select userid, userhost, terminal, timestamp,
  717.          obj$creator, obj$name, t.action action, act.name action_name, 
  718.          substr(auth$privileges,1,1) connect$,
  719.          substr(auth$privileges,2,1) dba$,
  720.          substr(auth$privileges,3,1) resource$,
  721.          auth$grantee, new$name,
  722.          sessionid, entryid, statement, returncode
  723.    from  sys.aud$ t, audit_actions act
  724.    where t.action = act.action
  725.      and (t.action between 24 and 25
  726.           or t.action between 64 and 73)
  727. /
  728. rem
  729. rem    AUDIT_EXISTS:  Lists audit trail entries produced by AUDIT NOT EXISTS.
  730. rem                   This is all audit trail entries with return codes of
  731. rem                   942, 943, 959, 1418, 1432, 1434, 1435, 2019 and 2289.
  732. rem                   This view is accessible to DBAs only.
  733. rem
  734. drop view AUDIT_EXISTS;
  735. create view AUDIT_EXISTS as
  736.   select userid, userhost, terminal, timestamp,
  737.          obj$creator, obj$name, t.action action, act.name action_name, 
  738.          auth$privileges, auth$grantee, new$name,
  739.          sessionid, entryid, statement, returncode
  740.   from sys.aud$ t, audit_actions act
  741.   where t.action = act.action
  742.     and returncode in (942, 943, 959, 1418, 1432, 1434, 1435, 2019, 2289)
  743. /
  744. rem
  745. rem  AUDIT_CONNECT: Lists the audit trail entries produced by AUDIT CONNECT.
  746. rem                 DBA's see all entries, while ordinary users only
  747. rem                 see entries for their own logins/logoffs.
  748. rem
  749. drop view AUDIT_CONNECT;
  750. rem
  751. create view AUDIT_CONNECT as
  752.   select userid, userhost, terminal, 
  753.          decode(action, 60, 'LOGON', 61, 'LOGOFF', 62, 'CLEANUP') action_name,
  754.          timestamp, logoff$time,
  755.          logoff$lread, logoff$pread, logoff$lwrite, logoff$dead,
  756.          sessionid, returncode
  757.   from sys.aud$
  758.   where action between 60 and 62
  759.     and (userid = user 
  760.          or exists
  761.            (select null 
  762.             from  sys.user$
  763.             where user# = uid and dba$ = 1
  764.        )
  765.     )
  766. /
  767. grant select on AUDIT_CONNECT to public;
  768. rem
  769. rem  SESSIONS:  same as AUDIT_CONNECT but with different column names
  770. rem             for backward compatiblity.
  771. rem
  772. drop view SESSIONS;
  773. create view SESSIONS (userid, userhost, terminal, status, logon, logoff, 
  774.               logread, physread, logwrite, deadlocks, sessionid, 
  775.               cleanup_error) as
  776.   select userid, userhost, terminal, 
  777.          decode(action, 60, 'LOGON', 61, 'LOGOFF', 62, 'CLEANUP'),
  778.          timestamp, logoff$time,
  779.          logoff$lread, logoff$pread, logoff$lwrite, logoff$dead,
  780.          sessionid, returncode
  781.   from sys.aud$
  782.   where action between 60 and 62
  783.     and (userid = user 
  784.          or exists
  785.            (select null 
  786.         from  sys.user$
  787.             where user# = uid and dba$ = 1
  788.        )
  789.     )
  790. /
  791. grant select on SESSIONS to public;
  792. rem
  793. rem     AUDIT_ACCESS: Lists audit trail entries produced by 
  794. rem                   AUDIT <options> ON <table_name> ... 
  795. rem                   DBA's see all entries, while ordinary users only
  796. rem                   see entries for their own tables.
  797. rem
  798. drop view AUDIT_ACCESS;
  799. create view AUDIT_ACCESS as
  800.  select userid, userhost, terminal, timestamp,
  801.     obj$creator, obj$name, t.action action, act.name action_name, 
  802.     new$name, auth$privileges, auth$grantee,
  803.     substr(ses$actions,1,1) alt,
  804.     substr(ses$actions,2,1) aud,
  805.     substr(ses$actions,3,1) com,
  806.     substr(ses$actions,4,1) del,
  807.     substr(ses$actions,5,1) gra,
  808.     substr(ses$actions,6,1) ind,
  809.     substr(ses$actions,7,1) ins,
  810.     substr(ses$actions,8,1) loc,
  811.     substr(ses$actions,9,1) ren,
  812.     substr(ses$actions,10,1) sel,
  813.     substr(ses$actions,11,1) upd,
  814.     sessionid, entryid, statement, returncode
  815.  from sys.aud$ t, audit_actions act
  816.  where  t.action = act.action  
  817.    and t.action <= 63
  818.    and not (t.action in (1,4,5,8,11,12,13,14,19,20,21,22,24,25,60,61,62))
  819.    and (t.obj$creator = user 
  820.     or exists
  821.       (select null 
  822.        from     sys.user$
  823.        where user# = uid and dba$ = 1
  824.       )
  825.        )
  826. grant select on AUDIT_ACCESS to public;
  827. drop view dblinks;
  828. create view dblinks (name, type, host, userid) as
  829.   select name, decode(owner#, 1, 'PUBLIC', 'PRIVATE'), host, userid
  830.   from  sys.link$
  831.   where owner# in (1,uid)
  832. /
  833. grant select on dblinks to public;
  834. drop view sysdblinks;
  835. create view sysdblinks (owner, name, host, userid) as
  836.   select u.name, l.name, l.host, l.userid
  837.   from  sys.user$ u, sys.link$ l
  838.   where u.user# = l.owner#
  839. /
  840. rem
  841. rem Describe database parameters. The information is from a pseudotable, which
  842. rem is not implemented yet.
  843. rem Archivelog = Y/N, type = SHARED/EXCLUSIVE, status = OPEN/CLOSE
  844. rem
  845. rem create view sysdatabase (dbname, logfile, archivelog, type, status)
  846. rem   select * from ??
  847. rem
  848.  
  849. drop view systabspaces;
  850. create view systabspaces (tsname,  status, blocksize, dflminext,
  851.               dflmaxext, dflinitial, dflnext, dflpctinc) as
  852.   select ts.name, decode(ts.online$, 1, 'ONLINE', 2, 'OFFLINE', 'UNDEFINED'), 
  853.      ts.blocksize, ts.dflminext,
  854.      ts.dflmaxext, ts.dflinit, ts.dflincr, ts.dflextpct
  855.   from  sys.ts$ ts
  856.   where ts.online$ != 3
  857. /
  858. drop view tabspaces;
  859. create view tabspaces (tsname, status, blocksize, dflminext,
  860.                dflmaxext, dflinitial, dflnext, dflpctinc) as
  861.   select ts.name, decode(ts.online$, 1, 'ONLINE', 2, 'OFFLINE', 'UNDEFINED'), 
  862.      ts.blocksize, ts.dflminext,
  863.      ts.dflmaxext, ts.dflinit, ts.dflincr, ts.dflextpct
  864.   from  sys.ts$ ts
  865.   where ts.online$ != 3 and ts.ts# in 
  866.           (select ts# from sys.tsq$ 
  867.            where  user# in (uid, 1) 
  868.            union
  869.            select ts# from sys.ts$
  870.            where  exists
  871.           (select null from sys.user$
  872.                    where  (resource$ = 1 or dba$ = 1) and user# = uid)
  873.           )
  874. /
  875. grant select on tabspaces to public;
  876. drop view sysfiles;
  877. create view sysfiles (tsname, fname, blocks) as
  878.   select ts.name, dbf.name, f.blocks
  879.   from  sys.ts$ ts, sys.file$ f, sys.v$dbfile dbf
  880.   where ts.ts# = f.ts#(+) and dbf.file# = f.file# and f.status$ = 2
  881. /
  882. drop view systsquotas_;
  883. create view systsquotas_ (tsname, username, userid, blocks, maxblocks) as
  884.   select ts.name, u.name, tsq.user#, tsq.blocks, tsq.maxblocks
  885.   from  sys.user$ u, sys.tsq$ tsq, sys.ts$ ts
  886.   where u.user# = tsq.user#
  887.     and tsq.ts# = ts.ts#
  888. /
  889. drop view systsquotas;
  890. create view systsquotas (username, tsname, blocks, maxblocks) as
  891.   select username, tsname, blocks, maxblocks
  892.   from  systsquotas_
  893. /
  894. drop view tsquotas;
  895. create view tsquotas (tsname, blocks, maxblocks) as
  896.   select tsname, blocks, maxblocks
  897.   from  systsquotas_
  898.   where userid = uid
  899. /
  900. grant select on tsquotas to public;
  901. drop view sysrollbackseg;
  902. create view sysrollbackseg (segname, tbaspace, segstatus) as
  903.   select u.name, ts.name, 
  904.      decode(u.status$, 2, 'AVAILABLE', 3, 'INUSE', 
  905.                4, 'OFFLINE', 5, 'NEED RECOVERY', 'UNDEFINED')
  906.   from  sys.undo$ u, sys.ts$ ts, sys.seg$ s
  907.   where u.status$ != 1 and u.file# = s.file# and u.block# = s.block#
  908.     and s.ts# = ts.ts#
  909. /
  910. drop table dtab;
  911. create table dtab(tname char(14),remarks char(64));
  912. insert into dtab values ('Reference Date',
  913.   'ORACLE catalog as of 10-Oct-85, installed on '||
  914.   to_char(sysdate,'dd-MON-yy hh24:mi:ss.'));
  915. insert into dtab values ('AUDIT_ACCESS',
  916.   'Audit entries for accesses to user''s tables/views (DBA sees all)');
  917. insert into dtab values ('AUDIT_ACTIONS',
  918.   'Maps auditing action numbers to action names');
  919. insert into dtab values ('AUDIT_CONNECT',
  920.   'Audit trail entries for user logon/logoff (DBA sees all users)');
  921. insert into dtab values ('AUDIT_DBA',
  922.    'Audit trail entries for DBA activities -- for DBA use only');
  923. insert into dtab values ('AUDIT_EXISTS',
  924.    'Audit trail entries for objects which do NOT EXIST -- DBA''s only');
  925. insert into dtab values ('AUDIT_TRAIL',
  926.    'Audit trail entries relevant to the user (DBA sees all)');
  927. insert into dtab values ('CATALOG',
  928.   'Tables and views accessible to user (excluding data dictionary)');
  929. insert into dtab values ('CLUSTERS',
  930.   'Clusters and their tables (either must be accessible to user)');
  931. insert into dtab values ('CLUSTERCOLUMNS',
  932.   'Maps cluster columns to clustered table columns');
  933. insert into dtab values ('COL',
  934.   'Specifications of columns in tables created by the user');
  935. insert into dtab values ('COLUMNS',
  936.   'Columns in tables accessible to user (excluding data dictionary)');
  937. insert into dtab values ('DBLINKS',
  938.   'Public and private links to external databases');
  939. insert into dtab values ('DEFAULT_AUDIT',
  940.    'Default table auditing options');
  941. insert into dtab values ('DTAB',
  942.   'Description of tables and views in Oracle Data Dictionary');
  943. insert into dtab values ('EXTENTS',
  944.   'Data structure of extents within tables');
  945. insert into dtab values ('INDEXES',
  946.   'Indexes created by user and indexes on tables created by user');
  947. insert into dtab values ('FREESPACE',
  948.   'Free extents available in the system -- for DBA use only');
  949. insert into dtab values ('PRIVATESYN',
  950.   'Private synonyms created by the user');
  951. insert into dtab values ('PUBLICSYN',
  952.   'Public synonyms');
  953. insert into dtab values ('SEQUENCES',
  954.   'Sequences created by the user');
  955. insert into dtab values ('SESSIONS',
  956.   'Audit trail entries for the user''s sessions (DBA sees all)');
  957. insert into dtab values ('STORAGE',
  958.   'Data and Index storage allocation for user''s own tables');
  959. insert into dtab values ('SYNONYMS',
  960.   'Synonyms, private and public');
  961. insert into dtab values ('SYSAUDIT_TRAIL',
  962.   'Synonym for sys.audit_trail -- for DBA use only');
  963. insert into dtab values ('SYSCATALOG',
  964.   'Profile of tables and views accessible to the user');
  965. insert into dtab values ('SYSCOLAUTH',
  966.   'Directory of column update access granted by or to the user');
  967. insert into dtab values ('SYSCOLUMNS',
  968.   'Specifications of columns in accessible tables and views');
  969. insert into dtab values ('SYSDATABASE',
  970.   'Parameters of databases');
  971. insert into dtab values ('SYSDBLINKS',
  972.   'All links to external databases -- for DBA use only');
  973. insert into dtab values ('SYSEXTENTS',
  974.   'Data structure of tables throughout system -- for DBA use only');
  975. insert into dtab values ('SYSFILES',
  976.   'Files allocation -- for DBA use only');
  977. insert into dtab values ('SYSINDEXES',
  978.   'List of indexes, underlying columns, creator, and options');
  979. insert into dtab values ('SYSCONSTRAINTS',
  980.   'Constraint definitions');
  981. insert into dtab values ('SYSCONSTRACOLS',
  982.   'Columns of primary keys, unique keys, and foreign keys');
  983. insert into dtab values ('SYSSEQUENCES',
  984.   'List of accessible sequences');
  985. insert into dtab values ('SYSSTORAGE',
  986.   'Summary of all database storage -- for DBA use only');
  987. insert into dtab values ('SYSTABALLOC',
  988.   'Data and index space allocations for all tables -- for DBA''s');
  989. insert into dtab values ('SYSTABAUTH',
  990.   'Directory of access authorization granted by or to the user');
  991. insert into dtab values('SYSTABSPACES',
  992.   'Parameters of tablespaces -- for DBA use only');
  993. insert into dtab values ('SYSTSQUOTAS',
  994.   'Space privileges granted to users -- for DBA use only');
  995. insert into dtab values ('SYSTEM_AUDIT',
  996.   'System auditing options -- for DBA use only');
  997. insert into dtab values ('SYSROLLBACKSEG',
  998.   'Rollback segments for tablespaces -- for DBA use only');
  999. insert into dtab values ('SYSUSERAUTH',
  1000.   'Master list of Oracle users -- for DBA use only');
  1001. insert into dtab values ('SYSUSERLIST',
  1002.   'List of Oracle users' );
  1003. insert into dtab values ('SYSVIEWS',
  1004.   'List of accessible views' );
  1005. insert into dtab values ('TAB',
  1006.   'List of tables, views, clusters and synonyms created by the user');
  1007. insert into dtab values ('TABALLOC',
  1008.   'Data and index space allocations for all user''s tables');
  1009. insert into dtab values ('TABQUOTAS',
  1010.   'Table allocation (space) parameters for tables created by user');
  1011. insert into dtab values('TABSPACES',
  1012.   'Parameters of tablespaces accessible by current user');
  1013. insert into dtab values ('TABLE_AUDIT',
  1014.   'Auditing options of user''s tables and views (DBA sees all)');
  1015. insert into dtab values ('TSQUOTAS',
  1016.   'Space privileges granted to current user');
  1017. insert into dtab values ('VIEWS',
  1018.   'Defining SQL statements for views created by the user');
  1019. grant select on dtab to public;
  1020. create synonym system.dual for dual;
  1021. create public synonym dual for dual;
  1022. create synonym system.taballoc for taballoc;
  1023. create public synonym taballoc for taballoc;
  1024. create synonym system.storage for storage;
  1025. create public synonym storage for storage;
  1026. create synonym system.extents for extents;
  1027. create public synonym extents for extents;
  1028. create synonym system.freespace for freespace;
  1029. create public synonym freespace for freespace;
  1030. create synonym system.syscolumns for syscolumns;
  1031. create public synonym syscolumns for syscolumns;
  1032. create synonym system.columns for columns;
  1033. create public synonym columns for columns;
  1034. create synonym system.syscatalog for syscatalog;
  1035. create public synonym syscatalog for syscatalog;
  1036. create synonym system.catalog for catalog;
  1037. create public synonym catalog for catalog;
  1038. create synonym system.sysindexes for sysindexes;
  1039. create public synonym sysindexes for sysindexes;
  1040. create synonym system.sysconstraints for sysconstraints;
  1041. create public synonym sysconstraints for sysconstraints;
  1042. create synonym system.sysconstracols for sysconstracols;
  1043. create public synonym sysconstracols for sysconstracols;
  1044. create synonym system.indexes for indexes;
  1045. create public synonym indexes for indexes;
  1046. create synonym system.views for views;
  1047. create public synonym views for views;
  1048. create synonym system.sysviews for sysviews;
  1049. create public synonym sysviews for sysviews;
  1050. create synonym system.sequences for sequences;
  1051. create public synonym sequences for sequences;
  1052. create synonym system.syssequences for syssequences;
  1053. create public synonym syssequences for syssequences;
  1054. create synonym system.systabauth for systabauth;
  1055. create public synonym systabauth for systabauth;
  1056. create synonym system.syscolauth for syscolauth;
  1057. create public synonym syscolauth for syscolauth;
  1058. create synonym system.sysuserlist for sysuserlist;
  1059. create public synonym sysuserlist for sysuserlist;
  1060. create synonym system.synonyms for synonyms;
  1061. create public synonym synonyms for synonyms;
  1062. create synonym system.publicsyn for publicsyn;
  1063. create public synonym publicsyn for publicsyn;
  1064. create synonym system.privatesyn for privatesyn;
  1065. create public synonym privatesyn for privatesyn;
  1066. create synonym system.tab for tab;
  1067. create public synonym tab for tab;
  1068. create synonym system.col for col;
  1069. create public synonym col for col;
  1070. create synonym system.tabquotas for tabquotas;
  1071. create public synonym tabquotas for tabquotas;
  1072. create synonym system.dtab for dtab;
  1073. create public synonym dtab for dtab;
  1074. create synonym system.sysfiles for sysfiles;
  1075. create public synonym sysfiles for sysfiles;
  1076. create synonym system.systaballoc for systaballoc;
  1077. create public synonym systaballoc for systaballoc;
  1078. create synonym system.sysstorage for sysstorage;
  1079. create public synonym sysstorage for sysstorage;
  1080. create synonym system.sysextents for sysextents;
  1081. create public synonym sysextents for sysextents;
  1082. create synonym system.sysuserauth for sysuserauth;
  1083. create public synonym sysuserauth for sysuserauth;
  1084. rem create public synonym sysdatabase for sysdatabase;
  1085. create synonym system.systabspaces for systabspaces;
  1086. create public synonym systabspaces for systabspaces;
  1087. create synonym system.tabspaces for tabspaces;
  1088. create public synonym tabspaces for tabspaces;
  1089. create synonym system.systsquotas for systsquotas;
  1090. create public synonym systsquotas for systsquotas;
  1091. create synonym system.tsquotas for tsquotas;
  1092. create public synonym tsquotas for tsquotas;
  1093. create synonym system.sysrollbackseg for sysrollbackseg;
  1094. create public synonym sysrollbackseg for sysrollbackseg;
  1095. create synonym system.system_audit for system_audit;
  1096. create public synonym system_audit for system_audit;
  1097. create synonym system.default_audit for default_audit;
  1098. create public synonym default_audit for default_audit;
  1099. create synonym system.table_audit for table_audit;
  1100. create public synonym table_audit for table_audit;
  1101. create synonym system.audit_actions for audit_actions;
  1102. create public synonym audit_actions for audit_actions;
  1103. create synonym system.audit_trail for audit_trail;
  1104. create public synonym audit_trail for audit_trail;
  1105. create synonym system.sysaudit_trail for sys.audit_trail;
  1106. create public synonym sysaudit_trail for sys.audit_trail;
  1107. create synonym system.audit_dba for audit_dba;
  1108. create public synonym audit_dba for audit_dba;
  1109. create synonym system.audit_exists for audit_exists;
  1110. create public synonym audit_exists for audit_exists;
  1111. create synonym system.audit_connect for audit_connect;
  1112. create public synonym audit_connect for audit_connect;
  1113. create synonym system.sessions for sessions;
  1114. create public synonym sessions for sessions;
  1115. create synonym system.audit_access for audit_access;
  1116. create public synonym audit_access for audit_access;
  1117. create synonym system.clusters for clusters;
  1118. create public synonym clusters for clusters;
  1119. create synonym system.clustercolumns for clustercolumns;
  1120. create public synonym clustercolumns for clustercolumns;
  1121. create synonym system.dblinks for dblinks;
  1122. create public synonym dblinks for dblinks;
  1123. create synonym system.sysdblinks for sysdblinks;
  1124. create public synonym sysdblinks for sysdblinks;
  1125. rem EXIT;
  1126.