oracle.rst
author Oleksandr Gavenko <gavenkoa@gmail.com>
Thu, 05 Apr 2018 19:22:33 +0300
changeset 2243 eccc5846e1dd
parent 2231 2813a509381c
child 2244 7d8a914e06ee
permissions -rw-r--r--
Move data across DBes.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1403
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     1
.. -*- coding: utf-8; -*-
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     2
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     3
==================
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     4
 Oracle database.
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     5
==================
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     6
.. contents::
1905
fba288d59662 Include only local subsections into TOC. This prevent duplication of
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1625
diff changeset
     7
   :local:
1403
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     8
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
     9
Oracle database development environment.
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    10
========================================
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    11
2221
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    12
http://en.wikipedia.org/wiki/Oracle_SQL_Developer
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    13
  Integrated development environment (IDE) for working with
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    14
  SQL/PLSql in Oracle databases.
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    15
http://en.wikipedia.org/wiki/SQL*Plus
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    16
  An Oracle database client that can run SQL and PL/SQL commands
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    17
  and display their results.
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    18
http://en.wikipedia.org/wiki/Oracle_Forms
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    19
  Is a software product for creating screens that interact with an
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    20
  Oracle database. It has an IDE including an object navigator,
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    21
  property sheet and code editor that uses PL/SQL.
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    22
http://en.wikipedia.org/wiki/Oracle_JDeveloper
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    23
  JDeveloper is a freeware IDE supplied by Oracle Corporation. It
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    24
  offers features for development in Java, XML, SQL and PL/SQL,
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    25
  HTML, JavaScript, BPEL and PHP.
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    26
http://en.wikipedia.org/wiki/Oracle_Reports
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    27
  Oracle Reports is a tool for developing reports against data
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
    28
  stored in an Oracle database.
1403
8f86324134d6 Oracle database development environment.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents:
diff changeset
    29
2194
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    30
Useful PL/SQL stubs
1494
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    31
===================
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    32
2231
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    33
Declare executable block::
1494
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    34
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    35
  declare
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    36
  begin
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    37
    null;
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    38
  end;
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    39
  /
f7e956de0cd7 Useful PL/SQL stub.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1486
diff changeset
    40
2113
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    41
Using variables::
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    42
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    43
  declare
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    44
    x number;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    45
  begin
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    46
    select 1 into x from dual;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    47
  end;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    48
  /
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
    49
2194
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    50
Call procedure::
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    51
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    52
  create or replace procedure MY_PROC as
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    53
  begin
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    54
    null;
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    55
  end;
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    56
  /
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    57
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    58
  begin
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    59
    MY_PROC;
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    60
  end;
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    61
  /
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    62
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    63
Call function::
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    64
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    65
  create or replace function MY_FUN return number as
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    66
  begin
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    67
    return 42;
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    68
  end;
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    69
  /
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    70
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    71
  declare
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    72
    x NUMBER;
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    73
  begin
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    74
    ret := MY_FUN();
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    75
  end;
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    76
  /
60f74f8b5967 Call procedure/function.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2185
diff changeset
    77
2231
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    78
Common client options
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    79
=====================
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    80
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    81
Following options supports Sql*Plus, SQLcl, Oracle Developer.
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    82
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    83
Enabling printing::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    84
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    85
  set serveroutput on;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    86
  exec DBMS_OUTPUT.PUT_LINE('Hello');
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    87
  exec DBMS_OUTPUT.DISABLE();
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    88
  exec DBMS_OUTPUT.PUT_LINE('Silence');
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    89
  exec DBMS_OUTPUT.ENABLE();
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    90
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    91
Enable printing of query execution time::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    92
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    93
  set timing on;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    94
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    95
Sql*Plus client options
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    96
=======================
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    97
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    98
Enable printing execution plan stats::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
    99
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   100
  set autotrace on;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   101
  set autotrace off;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   102
  set autotrace on statistics;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   103
  set autotrace on explain;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   104
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   105
Disable printing of ``select`` result, show only stats::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   106
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   107
  set autotrace traceonly;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   108
  set autotrace traceonly on explain;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   109
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   110
Adjust date format.
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   111
===================
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   112
::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   113
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   114
  column parameter format a32;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   115
  column value format a32;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   116
  select parameter, value from v$nls_parameters;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   117
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   118
  alter session set NLS_DATE_FORMAT = 'yyyy-mm-dd HH:MI:SS';
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   119
  alter session set NLS_TIMESTAMP_FORMAT = 'MI:SS.FF6';
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   120
  alter session set NLS_TIME_FORMAT = 'HH24:MI:SS.FF6';
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   121
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   122
  alter session set TIME_ZONE = '+06:00';
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   123
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   124
  select sysdate from dual;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   125
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   126
Working with SQL/Plus
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   127
=====================
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   128
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   129
Show error details::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   130
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   131
  show errors;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   132
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   133
Modify output format::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   134
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   135
  set pagesize 40;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   136
  set linesize 400;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   137
2221
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
   138
Database info
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
   139
=============
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   140
1624
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   141
List of users::
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   142
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   143
  select distinct(OWNER) from ALL_TABLES;
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   144
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   145
List of current user owned tables::
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   146
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   147
  select * from USER_TABLES;
1624
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   148
  select TABLE_NAME from USER_TABLES;
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   149
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   150
List of tables by owner::
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   151
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   152
  select OWNER || '.' || TABLE_NAME from ALL_TABLES
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   153
    order by OWNER;
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   154
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   155
List of current user table sizes::
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   156
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   157
  select SEGMENT_NAME, SEGMENT_TYPE, sum(BYTES) from USER_EXTENTS
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   158
    group by SEGMENT_NAME, SEGMENT_TYPE order by sum(BYTES);
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   159
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   160
  select sum(BYTES) from USER_EXTENTS;
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   161
2185
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   162
Table indexes restricted to user::
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   163
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   164
  select * from USER_INDEXES order by TABLE_NAME;
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   165
2185
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   166
Table indexes available to user::
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   167
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   168
  select * from ALL_INDEXES order by TABLE_NAME;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   169
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   170
All table indexes::
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   171
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   172
  select * from DBA_INDEXES order by TABLE_NAME;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   173
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   174
View index columns::
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   175
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   176
  select * from DBA_IND_COLUMNS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   177
  select * from ALL_IND_COLUMNS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   178
  select * from USER_IND_COLUMNS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   179
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   180
Vie index expressions::
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   181
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   182
  select * from DBA_IND_EXPRESSIONS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   183
  select * from ALL_IND_EXPRESSIONS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   184
  select * from USER_IND_EXPRESSIONS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   185
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   186
List of index sizes::
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   187
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   188
  select index_name, table_name, sum(user_extents.bytes) as bytes from user_indexes
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   189
    left outer join user_extents on user_extents.segment_name = table_name
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   190
    group by index_name, table_name
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   191
    order by table_name;
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   192
2185
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   193
View index statistics::
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   194
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   195
  select * from DBA_IND_STATISTICS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   196
  select * from ALL_IND_STATISTICS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   197
  select * from USER_IND_STATISTICS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   198
  select * from INDEX_STATS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   199
1624
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   200
List of tables without primary keys::
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   201
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   202
  select OWNER || '.' || TABLE_NAME from ALL_TABLES
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   203
    where TABLE_NAME not in (
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   204
      select distinct TABLE_NAME from ALL_CONSTRAINTS where CONSTRAINT_TYPE = 'P'
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   205
    ) and OWNER in ('USER1', 'USER2')
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   206
    order by OWNER, TABLE_NAME;
baf11017516f List of tables by owner.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1623
diff changeset
   207
2216
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   208
List tables that has foreign key to given table::
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   209
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   210
  select * from SYS.USER_CONSTRAINTS cons
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   211
    join SYS.USER_CONSTRAINTS rcons on rcons.CONSTRAINT_NAME = cons.R_CONSTRAINT_NAME
2218
39e18e1912b7 Fix typo.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2217
diff changeset
   212
    where cons.CONSTRAINT_TYPE = 'R' and rcons.TABLE_NAME = 'TBL_NAME';
2216
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   213
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   214
  select * from SYS.USER_CONSTRAINTS cons
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   215
    join SYS.USER_CONSTRAINTS rcons on rcons.CONSTRAINT_NAME = cons.R_CONSTRAINT_NAME
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   216
    where cons.CONSTRAINT_TYPE = 'R' and rcons.TABLE_NAME like '%/_OLD' escape '/';
303e4963ffc5 List tables that has foreign key to given table.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2194
diff changeset
   217
2220
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   218
List of missing index for foreign key constraint::
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   219
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   220
  select
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   221
    case when b.table_name is null then 'unindexed' else 'indexed' end as status,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   222
    a.table_name      as table_name,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   223
    a.constraint_name as fk_name,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   224
    a.fk_columns      as fk_columns,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   225
    b.index_name      as index_name,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   226
    b.index_columns   as index_columns
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   227
  from (
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   228
    select
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   229
      a.table_name,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   230
      a.constraint_name,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   231
      listagg(a.column_name, ',') within group (order by a.position) fk_columns
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   232
    from user_cons_columns a, user_constraints b
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   233
    where
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   234
      a.constraint_name = b.constraint_name
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   235
      and b.constraint_type = 'R'
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   236
      and a.owner = b.owner
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   237
    group by a.table_name, a.constraint_name
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   238
  ) a, (
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   239
    select
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   240
      table_name,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   241
      index_name,
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   242
      listagg(c.column_name, ',') within group (order by c.column_position) index_columns
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   243
    from user_ind_columns c
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   244
    group by table_name, index_name
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   245
  ) b
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   246
  where a.table_name = b.table_name(+)
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   247
    and b.index_columns(+) like a.fk_columns || '%'
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   248
  order by 1 desc, 2;
f643c573f870 List of missing index for foreign key constraint.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2219
diff changeset
   249
2185
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   250
List of current constraints limited to current user::
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   251
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   252
  select * from USER_CONSTRAINTS;
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   253
2185
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   254
List of constraints available to user::
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   255
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   256
  select * from ALL_CONSTRAINTS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   257
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   258
List of all constraints::
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   259
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   260
  select * from DBA_CONSTRAINTS;
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   261
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   262
.. note::
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   263
   ``CONSTRAINT_TYPE``:
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   264
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   265
   * ``C`` (check constraint on a table)
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   266
   * ``P`` (primary key)
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   267
   * ``U`` (unique key)
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   268
   * ``R`` (referential integrity)
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   269
   * ``V`` (with check option, on a view)
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   270
   * ``O`` (with read only, on a view)
f31a1ff8d8d9 Discover indexes and constraints.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2147
diff changeset
   271
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   272
List of tablespaces::
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   273
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   274
  select distinct TABLESPACE_NAME from USER_TABLES;
1462
27d4d6c15cb4 Информация о таблицах в БД Oracle.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1403
diff changeset
   275
2112
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   276
List user objects::
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   277
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   278
  select OBJECT_NAME, OBJECT_TYPE from USER_OBJECTS
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   279
    order by OBJECT_TYPE, OBJECT_NAME;
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   280
1622
dec1fd4222e8 List of current user permissions.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1583
diff changeset
   281
List of current user permissions::
dec1fd4222e8 List of current user permissions.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1583
diff changeset
   282
1623
4496f9e49b7b Reformat code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1622
diff changeset
   283
  select * from SESSION_PRIVS;
1622
dec1fd4222e8 List of current user permissions.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1583
diff changeset
   284
dec1fd4222e8 List of current user permissions.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1583
diff changeset
   285
List of user permissions to tables::
dec1fd4222e8 List of current user permissions.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1583
diff changeset
   286
dec1fd4222e8 List of current user permissions.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1583
diff changeset
   287
  select * from ALL_TAB_PRIVS where TABLE_SCHEMA not like '%SYS' and TABLE_SCHEMA not like 'SYS%';
dec1fd4222e8 List of current user permissions.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1583
diff changeset
   288
1625
0fa6542d8c93 List of user privileges.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1624
diff changeset
   289
List of user privileges::
0fa6542d8c93 List of user privileges.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1624
diff changeset
   290
0fa6542d8c93 List of user privileges.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1624
diff changeset
   291
  select * from USER_SYS_PRIVS
0fa6542d8c93 List of user privileges.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1624
diff changeset
   292
  select * from USER_TAB_PRIVS
0fa6542d8c93 List of user privileges.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1624
diff changeset
   293
  select * from USER_ROLE_PRIVS
0fa6542d8c93 List of user privileges.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1624
diff changeset
   294
2219
f991bbf12a59 List of other users that have access to given user tables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2218
diff changeset
   295
List of other users that have access to given user tables::
f991bbf12a59 List of other users that have access to given user tables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2218
diff changeset
   296
f991bbf12a59 List of other users that have access to given user tables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2218
diff changeset
   297
  select * from ALL_TAB_PRIVS where GRANTOR = 'ME';
f991bbf12a59 List of other users that have access to given user tables.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2218
diff changeset
   298
2146
274a3e6678ba Dump how exactly field stored.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2137
diff changeset
   299
Dump how exactly field stored::
274a3e6678ba Dump how exactly field stored.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2137
diff changeset
   300
274a3e6678ba Dump how exactly field stored.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2137
diff changeset
   301
  select dump(date '2009-08-07') from dual;
274a3e6678ba Dump how exactly field stored.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2137
diff changeset
   302
  select dump(sysdate) from dual;
274a3e6678ba Dump how exactly field stored.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2137
diff changeset
   303
2217
3005f2860e3c Added link.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2216
diff changeset
   304
https://dba.stackexchange.com/questions/11047/how-to-retrieve-foreign-key-constraints-data/
3005f2860e3c Added link.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2216
diff changeset
   305
  How to retrieve foreign key constraints data.
3005f2860e3c Added link.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2216
diff changeset
   306
2111
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   307
Managing data files location
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   308
============================
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   309
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   310
To find out where is data files located run as ``sysdba``::
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   311
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   312
  select * from dba_data_files;
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   313
  select * from dba_temp_files;
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   314
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   315
Above files represent table spaces::
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   316
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   317
  select * from dba_tablespaces;
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   318
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   319
Another information about installation::
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   320
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   321
  select * from v$controlfile;
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   322
  select * from v$tablespace;
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   323
  select * from v$database;
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   324
  show parameter control_files;
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   325
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   326
Place for dumps::
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   327
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   328
  show parameter user_dump_dest;
f780f1b08e12 Managing data files location.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1912
diff changeset
   329
2112
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   330
Installing express edition
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   331
==========================
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   332
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   333
Disable APEX port
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   334
-----------------
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   335
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   336
Find APEX port in usage::
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   337
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   338
  select dbms_xdb.GetHttpPort, dbms_xdb.GetFtpPort from dual;
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   339
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   340
Disable APEX lisener (to free useful 8080 port) from ``system``::
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   341
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   342
  execute dbms_xdb.SetHttpPort(0);
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   343
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   344
or move to another port::
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   345
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   346
  execute dbms_xdb.SetHttpPort(8090);
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   347
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   348
http://stackoverflow.com/questions/165105/how-to-disable-oracle-xe-component-which-is-listening-on-8080
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   349
  How to disable Oracle XE component which is listening on 8080?
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   350
http://daust.blogspot.co.il/2006/01/xe-changing-default-http-port.html
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   351
  XE: Changing the default http port.
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   352
https://erikwramner.wordpress.com/2014/03/23/stop-oracle-xe-from-listening-on-port-8080/
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   353
  Stop Oracle XE from listening on port 8080.
86ec943e6823 List user objects.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2111
diff changeset
   354
2113
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   355
Creating user
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   356
-------------
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   357
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   358
From ``system`` account::
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   359
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   360
  create user BOB identified by 123456;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   361
  alter user BOB account unlock;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   362
  alter user BOB default tablespace USERS;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   363
  alter user BOB temporary tablespace TEMP;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   364
  alter user BOB quota 100M on USERS;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   365
  grant CREATE SESSION, ALTER SESSION to BOB;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   366
  grant CREATE PROCEDURE, CREATE TRIGGER to BOB;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   367
  grant CREATE TABLE, CREATE SEQUENCE, CREATE VIEW, CREATE SYNONYM to BOB;
6c7691230622 Creating user.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2112
diff changeset
   368
2226
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   369
Profiling
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   370
=========
1483
1475d464e8a8 Timing info about last queries.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1482
diff changeset
   371
2231
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   372
``explain plan for`` can be used to show probable execution plan for query::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   373
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   374
  explain plan for select 1 from dual;
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   375
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   376
``plan_table`` should be examined to display result::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   377
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   378
  select * from table(dbms_xplan.display);
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   379
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   380
To get actual execution plan run following after executing query::
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   381
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   382
  select * from table(dbms_xplan.display_cursor);
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   383
  select * from table(dbms_xplan.display_cursor(format => 'basic'));
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   384
  select * from table(dbms_xplan.display_cursor(format => 'typical'));
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   385
  select * from table(dbms_xplan.display_cursor(format => 'all'));
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   386
2226
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   387
Last queries' execution stats are available through ``v$sql`` view::
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   388
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   389
  grant select on v_$sql to BOB;
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   390
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   391
  select * from v$sql;
2231
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   392
  select * from v$sql_plan;
1483
1475d464e8a8 Timing info about last queries.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1482
diff changeset
   393
1475d464e8a8 Timing info about last queries.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1482
diff changeset
   394
  select LAST_LOAD_TIME, ELAPSED_TIME, MODULE, SQL_TEXT elasped from v$sql
1475d464e8a8 Timing info about last queries.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1482
diff changeset
   395
    order by LAST_LOAD_TIME desc
1475d464e8a8 Timing info about last queries.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1482
diff changeset
   396
1486
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   397
Improved version of above code::
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   398
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   399
  column LAST_LOAD_TIME format a20;
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   400
  column TIME format a20;
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   401
  column MODULE format a10;
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   402
  column SQL_TEXT format a60;
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   403
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   404
  set autotrace off;
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   405
  set timing off;
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   406
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   407
  select * from (
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   408
    select LAST_LOAD_TIME, to_char(ELAPSED_TIME/1000, '999,999,999.000') || ' ms' as TIME, MODULE, SQL_TEXT from SYS."V_\$SQL"
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   409
      where SQL_TEXT like '%BATCH_BRANCHES%'
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   410
      order by LAST_LOAD_TIME desc
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   411
    ) where ROWNUM <= 5;
f3be7476145d Improved version of code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1485
diff changeset
   412
2226
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   413
In SQL/Plus query execution time (up to )::
1484
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   414
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   415
  SET TIMING ON;
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   416
  -- do stuff
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   417
  SET TIMING OFF;
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   418
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   419
or::
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   420
2221
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
   421
  set serveroutput on;
99a73de48647 Re-indent code.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2220
diff changeset
   422
  variable n number;
1484
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   423
  exec :n := dbms_utility.get_time;
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   424
  select ......
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   425
  exec dbms_output.put_line( (dbms_utility.get_time-:n)/100) || ' seconds....' );
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   426
2136
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   427
In SQL Developer you get execution time in result window. By default SQL
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   428
Developer limit output to 50 rows. To run full query select result window nat
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   429
press ``Ctrl+End``.
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   430
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   431
Alternatively you may wrap you query with (and optionally use hint to disable
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   432
optimizations??)::
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   433
2231
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   434
  select count(*) from ( ... ORIGINAL QUERY ... );
2136
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   435
2137
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   436
Another option is::
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   437
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   438
  delete plan_table;
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   439
  explain plan for ... SQL statement ...;
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   440
  select time from plan_table where id = 0;
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   441
2226
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   442
.. note::
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   443
   From docs:
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   444
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   445
     PLAN_TABLE is automatically created as a global temporary table to hold the output of an EXPLAIN
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   446
     PLAN statement for all users. PLAN_TABLE is the default sample output table into which the
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   447
     EXPLAIN PLAN statement inserts rows describing execution plans.
d72d3ce66806 Last queries' execution stats.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2221
diff changeset
   448
1484
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   449
See:
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   450
2136
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   451
http://docs.oracle.com/cd/B19306_01/server.102/b14237/dynviews_2113.htm
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   452
  $SQL lists statistics on shared SQL area without the GROUP BY clause.
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   453
http://stackoverflow.com/questions/22198853/finding-execution-time-of-query-using-sql-developer
3f34a66e6a2a Finding Execution time of query using SQL Developer.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2114
diff changeset
   454
  Finding Execution time of query using SQL Developer.
2137
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   455
http://stackoverflow.com/questions/3559189/oracle-query-execution-time
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   456
  Oracle query execution time.
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   457
http://tkyte.blogspot.com/2007/04/when-explanation-doesn-sound-quite.html
81d0f561a4a3 explain plan.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2136
diff changeset
   458
   When the explanation doesn't sound quite right...
1484
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   459
1485
752e99dbb016 Last table modification time.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1484
diff changeset
   460
Last table modification time.
752e99dbb016 Last table modification time.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1484
diff changeset
   461
=============================
752e99dbb016 Last table modification time.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1484
diff changeset
   462
::
752e99dbb016 Last table modification time.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1484
diff changeset
   463
752e99dbb016 Last table modification time.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1484
diff changeset
   464
  select max(scn_to_timestamp(ora_rowscn)) from TBL;
752e99dbb016 Last table modification time.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1484
diff changeset
   465
752e99dbb016 Last table modification time.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1484
diff changeset
   466
  select timestamp from all_tab_modifications where table_owner = 'OWNER';
752e99dbb016 Last table modification time.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1484
diff changeset
   467
  select timestamp from all_tab_modifications where table_name = 'TABLE';
1484
20964d8677d7 Profiling.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1483
diff changeset
   468
1482
1a012d9fe613 List of Oracle Reserved Words.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1462
diff changeset
   469
List of Oracle Reserved Words.
1a012d9fe613 List of Oracle Reserved Words.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1462
diff changeset
   470
==============================
1a012d9fe613 List of Oracle Reserved Words.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1462
diff changeset
   471
2231
2813a509381c Common client options. Sql*Plus client options.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2226
diff changeset
   472
* http://docs.oracle.com/cd/B19306_01/em.102/b40103/app_oracle_reserved_words.htm
1496
7679a0100061 Adjust date format.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 1495
diff changeset
   473
2147
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   474
Find time zone
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   475
==============
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   476
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   477
Set TZ data formt::
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   478
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   479
  alter session set 'YYYY-MM-DD HH24:MI:SS.FF3 TZR';
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   480
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   481
For system TZ look to TZ in::
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   482
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   483
  select SYSTIMESTAMP from dual;
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   484
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   485
For session TZ look to TZ in::
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   486
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   487
  select CURRENT_TIMESTAMP from dual;
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   488
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   489
or directly in::
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   490
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   491
  select SESSIONTIMEZONE from dual;
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   492
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   493
You can adjust session TZ by::
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   494
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   495
  alter session set TIME_ZONE ='+06:00';
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   496
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   497
which affect on ``CURRENT_DATE``, ``CURRENT_TIMESTAMP``, ``LOCALTIMESTAMP``.
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   498
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   499
``DBTIMEZONE`` is set when database is created and can't be altered if the
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   500
database contains a table with a ``TIMESTAMP WITH LOCAL TIME ZONE`` column and
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   501
the column contains data::
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   502
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   503
  select DBTIMEZONE from dual;
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   504
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   505
Find time at timezone::
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   506
e6dcc210bd6b Find time zone.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2146
diff changeset
   507
  select SYSTIMESTAMP at time zone 'GMT' from dual;
2243
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   508
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   509
Move data across DBes
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   510
=====================
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   511
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   512
Format ``select`` data as ``insert`` statements with ``/*insert*/`` hind (use ``F5`` key in Oracle
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   513
developer)::
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   514
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   515
  select /*insert*/ * from tbl;
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   516
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   517
Another useful hint::
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   518
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   519
  select /*csv*/ * from tbl;
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   520
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   521
Alternatively enable output as ``insert`` statments (use ``F5`` key in Oracle developer)::
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   522
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   523
  set sqlformat insert;
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   524
  select * from tbl;
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   525
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   526
  spool /home/user/insert.sql;
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   527
  select * from tbl where ...;
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   528
  spool off;
eccc5846e1dd Move data across DBes.
Oleksandr Gavenko <gavenkoa@gmail.com>
parents: 2231
diff changeset
   529