mercredi 19 novembre 2014

Mode Archivelog

Voici une question pour vous aider à étudier pour l'examen OCA. Quelle commande peut-on utiliser pour savoir si une base de données soit en mode ARCHIVELOG?

A. archivelog list
B. show archive mode
C. archive log list
D. list archivelog

J'ai testé les choix  sur Oracle 12 de la manière suivante: 

SQL> conn / as sysdba
Connecté.
SQL> archivelog list
SP2-0734: commande inconnue au début de "archivelog..." - le reste de la ligne est ignoré.
SQL> show archive mode
SP2-0158: option SHOW inconnue "archive"
SP2-0158: option SHOW inconnue "mode"
SQL> archive log list
mode Database log              mode No Archive
Archivage automatique             Désactivé
Destination de l'archive             USE_DB_RECOVERY_FILE_DEST
Séquence de journal en ligne la plus ancienne     157
Séquence de journal courante            159
SQL> list archivelog
SP2-0223: Pas de lignes dans la mémoire tampon SQL.
SQL> 

Donc, la réponse correcte est C.

Pour quelque raison que je ne comprends pas, le résultat est meilleur rangé en anglais: 

SQL> conn / as sysdba
Connecté.
SQL> alter session set nls_language = 'ENGLISH';
 
Session altered.
 
SQL> archive log list
Database log mode              No Archive Mode
Automatic archival             Disabled
Archive destination            USE_DB_RECOVERY_FILE_DEST
Oldest online log sequence     157
Current log sequence           159
SQL>

mardi 4 novembre 2014

Connexion Comme SYSOPER

Voici une question pour vous aider à étudier pour l'examen OCA. Je me suis servi de la commande suivante pour me connecter à une base de données sur Oracle 12.1:

sqlplus fred/bloggs as sysoper

Ensuite j'ai tapé show user pour connaître le nom de l'utilisateur que j'employais. Quelle réponse Oracle m'a-t-il donnée?

A. SYSTEM
B. FRED
C. SYS
D. PUBLIC
E. SYSOPER

Voici ce que j'ai vu:

C:\Users\Andrew>sqlplus fred/bloggs as sysoper
 
SQL*Plus: Release 12.1.0.1.0 Production on Mar. Nov. 4 18:01:24 2014
 
Copyright (c) 1982, 2013, Oracle.  All rights reserved.
 
Connecté à :
Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production
With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options
 
SQL> show user
USER est "PUBLIC"
SQL> exit
Déconnecté de Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production
With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options
 
C:\Users\Andrew>

Donc, la réponse correcte est D.

samedi 1 novembre 2014

ORA-01951, ORA-01952 et ORA-01045

J'ai vu une question étrange sur un forum et j'ai décidé de la recréer dans une base de données sur Oracle version 12.1. D'abord j'ai créé un utilisateur:

SQL> conn / as sysdba
Connecté.
SQL> create user a identified by b
  2  /
 
Utilisateur créé.

SQL>

Ensuite j'ai découvert que l'utilisateur pouvait faire un login, apparemment, sans le privilège CREATE SESSION:

SQL> conn a/b
Connecté.
SQL>

Après avoir fait son login, l'utilisateur avait un rôle et deux privilèges:

SQL> col role format a30
SQL> select * from session_roles
  2  /
 
ROLE
------------------------------
CONNECT
 
SQL> col privilege format a30
SQL> select * from session_privs
  2  /
 
PRIVILEGE
------------------------------
SET CONTAINER
CREATE SESSION

SQL>

Cependant, quand j'ai essayé de révoquer le rôle, j'ai vu une erreur ORA-01951 et quand j'ai essayé de révoquer le privilège, j'au vu une erreur ORA-01952:

SQL> conn / as sysdba
Connecté.
SQL> revoke connect from a
  2  /
revoke connect from a
*
ERREUR à la ligne 1 :
ORA-01951: ROLE 'CONNECT' non accordé à 'A'
 
SQL> revoke create session from a
  2  /
revoke create session from a
*
ERREUR à la ligne 1 :
ORA-01952: privilèges du système non accordés à 'A'

SQL>

J'ai noté qu'on avait accordé CONNECT à PUBLIC:

SQL> col granted_role format a30
SQL> select granted_role
  2  from dba_role_privs
  3  where grantee = 'PUBLIC'
  4  /
 
GRANTED_ROLE
------------------------------
CONNECT

SQL>

Alors je l'ai révoqué:

SQL> revoke connect from public
  2  /
 
Suppression de privilèges (REVOKE) acceptée.

SQL>

... et le problème a disparu:

SQL> conn a/b
ERROR:
ORA-01045: l'utilisateur A n'a pas le privilège CREATE
SESSION ; connexion refusée
 
Avertissement : vous n'êtes plus connecté à ORACLE.
SQL>