forked from oracle-samples/db-sample-schemas
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmkverify.sql
218 lines (181 loc) · 5.98 KB
/
mkverify.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
Rem
Rem $Header: mkverify.sql 2015/03/19 10:23:26 smtaylor Exp $
Rem
Rem mkverify.sql
Rem
Rem Copyright (c) 2002, 2015, Oracle. All rights reserved.
Rem
Rem Permission is hereby granted, free of charge, to any person obtaining
Rem a copy of this software and associated documentation files (the
Rem "Software"), to deal in the Software without restriction, including
Rem without limitation the rights to use, copy, modify, merge, publish,
Rem distribute, sublicense, and/or sell copies of the Software, and to
Rem permit persons to whom the Software is furnished to do so, subject to
Rem the following conditions:
Rem
Rem The above copyright notice and this permission notice shall be
Rem included in all copies or substantial portions of the Software.
Rem
Rem THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
Rem EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
Rem MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
Rem NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
Rem LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
Rem OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
Rem WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Rem
Rem NAME
Rem mkverify.sql - Verify the Sample Schema creation
Rem
Rem DESCRIPTION
Rem Run various scripts against the dictionary
Rem
Rem NOTES
Rem Relies on accurate statistics being collected
Rem
Rem MODIFIED (MM/DD/YY)
Rem smtaylor 03/19/15 - added parameter 3, connect string
Rem smtaylor 03/19/15 - added @&connect_string to CONNECT
Rem cbauwens 08/09/04 - sorting of constraints
Rem ahunold 02/11/03 - sorting of object privileges
Rem ahunold 10/25/02 - Dimensions, XML
Rem ahunold 10/12/02 - DBA_ALL_TABLES, data types
Rem ahunold 09/25/02 - Created
Rem
PROMPT
PROMPT specify password for SYSTEM as parameter 1:
DEFINE password_system = &1
PROMPT
PROMPT specify spool filename as parameter 2:
DEFINE spool_file = &2
PROMPT
PROMPT specify connect string as parameter 3:
DEFINE connect_string = &3
PROMPT
CONNECT system/&password_system@&connect_string;
--
-- Workaround until situation with DBA_ALL_TABLES is clear
--
analyze table oe.categories_tab compute statistics;
analyze table oe.product_ref_list_nestedtab compute statistics;
analyze table oe.subcategory_ref_list_nestedtab compute statistics;
analyze table oe.purchaseorder compute statistics;
analyze table pm.textdocs_nestedtab compute statistics;
SET ECHO OFF
SET FEEDBACK 1
SET NUMWIDTH 10
SET LINESIZE 90
SET TRIMSPOOL ON
SET TAB OFF
SET PAGESIZE 999
COLUMN constraint_type FORMAT A20
COLUMN data_type FORMAT A35
COLUMN data_type_owner FORMAT A16
COLUMN dimension_name FORMAT A20
COLUMN generated FORMAT A16
COLUMN granted_role FORMAT A25
COLUMN grantee FORMAT A7
COLUMN grantor FORMAT A7
COLUMN index_name FORMAT A25
COLUMN object_name FORMAT A30
COLUMN object_type FORMAT A20
COLUMN owner FORMAT A6
COLUMN privilege FORMAT A25
COLUMN schema_owner FORMAT A16
COLUMN segment_type FORMAT A20
COLUMN status FORMAT A8
COLUMN storage_type FORMAT A20
COLUMN subobject_name FORMAT A16
COLUMN table_name FORMAT A30
COLUMN validated FORMAT A16
SPOOL &spool_file
PROMPT
PROMPT All named objects and stati
SELECT owner, object_type, object_name, subobject_name, status
FROM dba_objects
WHERE owner in ('HR','OE','SH','PM','IX','BI')
AND object_name NOT LIKE 'SYS%'
ORDER BY 1,2,3,4;
PROMPT
PROMPT Data types used
SELECT owner, data_type, data_type_owner, data_type_mod, COUNT(*)
FROM dba_tab_columns
WHERE owner in ('HR','OE','SH','PM','IX','BI')
GROUP BY owner, data_type, data_type_owner, data_type_mod
ORDER BY 2,1,3,4;
PROMPT
PROMPT XML tables
SELECT owner, table_name, schema_owner, storage_type
FROM dba_xml_tables
WHERE owner in ('HR','OE','SH','PM','IX','BI')
ORDER BY 1,2;
PROMPT
PROMPT All objects named 'SYS%' (LOBs etc)
SELECT owner, object_type, status, COUNT(*)
FROM dba_objects
WHERE owner in ('HR','OE','SH','PM','IX','BI')
AND object_name LIKE 'SYS%'
GROUP BY owner, object_type, status
ORDER BY 2,1,3;
PROMPT
PROMPT All constraints
SELECT owner,
DECODE (constraint_type ,
'C', 'Check or Not Null' ,
'O', 'Read only view' ,
'P', 'Primary key' ,
'R', 'Foreign key' ,
'U', 'Unique key' ,
'V', 'With check view' ) CONSTRAINT_TYPE ,
status,
validated,
generated,
COUNT(*)
FROM dba_constraints
WHERE owner in ('HR','OE','SH','PM','IX','BI')
GROUP BY owner, constraint_type, status, validated, generated
ORDER BY 2,3,4,5,1;
PROMPT
PROMPT All dimensions
SELECT owner, dimension_name, invalid, compile_state
FROM dba_dimensions
WHERE owner in ('HR','OE','SH','PM','IX','BI')
ORDER BY 1,2;
PROMPT
PROMPT All granted roles
SELECT granted_role, grantee
FROM dba_role_privs
WHERE grantee in ('HR','OE','SH','PM','IX','BI')
ORDER BY 1,2;
PROMPT
PROMPT All granted system privileges
SELECT privilege, grantee
FROM dba_sys_privs
WHERE grantee in ('HR','OE','SH','PM','IX','BI')
ORDER BY 1,2;
PROMPT
PROMPT All granted object privileges
SELECT owner, table_name, privilege, grantee
FROM dba_tab_privs
WHERE grantee in ('HR','OE','SH','PM','IX','BI')
ORDER BY 1,2,3,4;
PROMPT
PROMPT Space usage
SELECT owner, segment_type, sum(bytes)
FROM dba_segments
WHERE owner in ('HR','OE','SH','PM','IX','BI')
GROUP BY ROLLUP (owner, segment_type);
PROMPT
PROMPT Table cardinality relational and object tables
SELECT owner, table_name, num_rows
FROM dba_all_tables
WHERE owner in ('HR','OE','SH','PM','IX','BI')
ORDER BY 1,2,3;
PROMPT
PROMPT Index cardinality (without LOB indexes)
SELECT owner, index_name, distinct_keys, num_rows
FROM dba_indexes
WHERE owner in ('HR','OE','SH','PM','IX','BI')
AND index_name NOT LIKE 'SYS%'
ORDER BY 1,2,3;
SPOOL OFF