11 septembre 2018

Comment devenir un autre utilisateur sous Oracle?

IntroductionComment un user peut-il interagir avec les objets d'un autre user? Est-ce facile? Impossible? Les problématiques de droits et de rôles sont complexes avec Oracle mais il existe différentes techniques permettant à un user U1 d'accéder aux objets d'un user U2 et c'est ce que nous allons voir.  Points d'attentionTrop pour les énumérer :-) Base de testsN'importe quelle base Oracle. ExemplesDans la suite de cet article, j'utiliserais les conventions suivantes : - U1 : user zztest, avec le droit CREATE SESSION au... [Lire la suite]
Posté par David DBA à 10:33 - - Permalien [#]
Tags : ,

25 août 2018

EXPLAIN PLAN et AUTOTRACE : même combat?

IntroductionVous savez que pour avoir rapidement un plan d'exécution sous Oracle, il faut utiliser la commande EXPLAIN PLAN. Cela permet de ne pas attendre une heure que s'exécute la requête mais attention aux bind variables, elles ne sont pas gérées. Pour avoir le vrai plan, calculé par le CBO, utilisez en revanche dbms_xplan.display_cursor (ou bien dbms_xplan.display_awr) qui lui gère parfaitement les bind variables mais attention au temps d'exécution.     Et la commande AUTOTRACE, elle génère un vrai plan ou un... [Lire la suite]
Posté par David DBA à 09:36 - - Permalien [#]
Tags : , , ,
15 août 2018

Le type de données VARCHAR : est-il utilisé par Oracle dans la définition de tables?

IntroductionLe type de données (datatype) VARCHAR, à ne pas confondre avec VARCHAR2, excite depuis 1992 la curiosité de bien des DBA. Ce datatype est apparu avec Oracle 7 et, dès le début, Oracle a dit de ne pas l'utiliser car il était réservé pour un usage futur. En 2018, soit 26 ans après, Oracle nous dit toujours de ne pas l'utiliser :-) que c'est long le futur...Et comme je suis quelqu'un de très curieux, j'ai eu envie de voir cela de plus près!  Points d'attentionAucun... Base de testsN'importe quelle base Oracle. ... [Lire la suite]
Posté par David DBA à 12:54 - - Permalien [#]
Tags : ,
05 août 2018

Indexer la valeur NULL et l'utiliser dans la clause WHERE

Introduction"Oracle n'indexe pas la valeur NULL" : combien de fois j'ai lu cela... il faudrait ajouter, pour être plus précis, "sauf sous certaines conditions", que nous allons voir de suite :-)   Points d'attentionNA.   Base de testsN'importe quelle base Oracle; tests sur une 12.1.     ExemplesOn crée une table de test basique, avec 10 000 enregistrements.     SQL> create table TEST_NULL (ID NUMBER, NAME VARCHAR2(30 CHAR));     Table... [Lire la suite]
Posté par David DBA à 22:09 - - Permalien [#]
Tags : , ,
10 juillet 2018

Problème de caractères spéciaux et d'accents dans le nom d'objets

IntroductionDans tout logiciel ou langage informatique, il existe des caractères spéciaux. En général il faut les manipuler avec précaution sinon vous risquez d'avoir de très très mauvaises surprises. Nous allons voir cela avec le nom des objets sous Oracle.   Points d'attentionNA.   Base de testsN'importe quelle base Oracle; tests sur une 12.1.     Exemples============================================================================================Nom de table avec des caractères... [Lire la suite]
Posté par David DBA à 17:32 - - Permalien [#]
Tags : ,
20 juin 2018

Comment créer un trigger sur SELECT

IntroductionOracle permet de créer des triggers sur les opérations DML suivantes : INSERT, UPDATE, DELETE mais pas SELECT. Nous allons voir comment contourner cette restriction avec un audit de granularité fine créé via le package DBMS_FGA, et, lorsque l'audit se déclenchera, celui-ci appellera une procédure stockée.Un SELECT qui exécute du code PL/SQL : cela ressemble fortement à un trigger sur SELECT, non? Attention, c'est un pseudo-trigger, de niveau Statement et pas de niveau Row : si le SELECT ramène 100 lignes, la procédure... [Lire la suite]
Posté par David DBA à 10:00 - - Permalien [#]
Tags : , ,

02 juin 2018

Jointure d'index : le INDEX FAST FULL SCAN n'est pas optimisé par Oracle

IntroductionLe but de cet article est de discuter du mode d'accès aux index appelé INDEX FAST FULL SCAN, et plus précisément de montrer qu'il n'est pas optimisé (oui, c'est prétentieux de ma part) lors d'une jointure d'index. Pour cela nous allons utiliser un hint et montrer que Oracle lit TOUS les blocs de l'index puis filtre les données au lieu de traiter N blocs d'un coup et de s'arrêter une fois tous les enregistrements trouvés, ce qui serait plus pertinent. Bien sur, INDEX FAST FULL SCAN signifie "lecture rapide de TOUT l'index"... [Lire la suite]
Posté par David DBA à 18:57 - - Permalien [#]
Tags : ,
29 avril 2018

Les plus vieux fichiers d'Oracle pour créer une base datent de 1987

IntroductionLa base de données Oracle est un logiciel existant depuis 1979, soit presque 40 ans!Celle-ci a incroyablement évolué depuis ses débuts, songez que sa première version ne supportait pas les transactions mais seulement les fonctionnalités SQL basiques de requête et jointure... pour info le COMMIT/ROLLBACK ne fut introduit que sur la V3.Depuis ces temps quasi-préhistoriques, de très (trop?) nombreuses fonctionnalités ont disparu, sont devenues Deprecated, Unsuported puis Obsoletes... Et donc, ma question est, existe t-il... [Lire la suite]
Posté par David DBA à 19:42 - - Permalien [#]
Tags : ,
04 avril 2018

Trouver la liste des commandes DML et DDL gérées par Oracle : vue V$SQLCOMMAND

     IntroductionLe dictionnaire de données d'Oracle renferme des milliers de vues; il est bien sur impossible de toutes les explorer mais certaines, au détour d'un livre ou d'un forum, m'ont bien plu. Par exemple V$SQLCOMMAND dont la définition est "displays the mapping between SQL opcodes and names" : en clair, c'est la liste de toutes les commandes Oracle qu'on peut exécuter :-)Vous les connaissez déjà toutes? Vous êtes sur? Y compris UPSERT? Y compris UNDROP OBJECT?   Points d'attentionNA.   ... [Lire la suite]
Posté par David DBA à 23:04 - - Permalien [#]
Tags : , ,
17 février 2018

Trace 10046 et base 12c CDB : ordres exécutés par Oracle lors d'un CREATE TABLE ?

IntroductionDans cet article "Quels sont les ordres exécutés par Oracle lors d'un CREATE TABLE ? Trace 10046 et base 12c non CDB", nous avons regardé quels ordres SQL Oracle exécutait lors d'un CREATE TABLE dans une base 12c non CDB. Maintenant, nous allons voir la même chose mais pour une base CDB. Je mettrais beaucoup moins de commentaires car ces ordres sont bien plus nombreux, certaines sont assez explicites (notamment quand Oracle donne le type des opérations) alors que d'autres restent totalement obscurs. Points... [Lire la suite]
Posté par David DBA à 22:36 - - Permalien [#]
Tags : ,