IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

SQL Oracle Discussion :

VARCHAR2 et chaines caractères vide ''


Sujet :

SQL Oracle

  1. #21
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 183
    Points : 36
    Points
    36
    Par défaut
    Citation Envoyé par c.langlet Voir le message
    je vais peut-être dire une bêtise, mais si le besoin est constant et sur toutes les tables et requête, est-ce que les alter ne peuvent pas être fait sur la base au lieu de la session ?

    Edit:
    Je confirme , c'est une bêtise , car d'après mon tests on peut dire adieu au index ( a moins qu'il y ai un moyen de contourner ?)
    C'est aussi ce que je cherche à paramétrer Oracle en case insensitive !!!

  2. #22
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Citation Envoyé par kilicool Voir le message
    Il faudrait pouvoir voir si le pool de connexion sur WebLogic à la possibilité d'effectuer des alter pour la préparation !
    Oublié le WebLogic. Vous allez définir dans votre base Oracle un trigger After Logon qui à la connexion de votre utilisateur Oracle execute le Alter en question.

  3. #23
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 183
    Points : 36
    Points
    36
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Oublié le WebLogic. Vous allez définir dans votre base Oracle un trigger After Logon qui à la connexion de votre utilisateur Oracle execute le Alter en question.
    Ok, pouvez vous m'envoyer ce trigger svp ?

  4. #24
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 183
    Points : 36
    Points
    36
    Par défaut
    J'ai essayé ça mais ça ne semble pas fonctionner (le trigger est erroné)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    create or replace trigger
       logon_session_trigger
    AFTER LOGON ON DATABASE
    BEGIN
    alter session set NLS_SORT=BINARY_CI;
    alter session set NLS_COMP=LINGUISTIC;
    END;
    /

  5. #25
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Alter session ne peut pas être employé directement dans PL/SQL.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    CREATE OR REPLACE TRIGGER
       logon_session_trigger
    AFTER LOGON ON DATABASE
    BEGIN
      if sys_context('USERENV','SESSION_USER') = 'MNI' Then
        Execute Immediate 'ALTER session SET NLS_SORT=BINARY_CI';
        Execute Immediate 'ALTER session SET NLS_COMP=LINGUISTIC';
      end if;  
    END;
    /

  6. #26
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Citation Envoyé par kilicool Voir le message
    Ok, pouvez vous m'envoyer ce trigger svp ?
    Ce déclencheur, ce n'est que la cosmétique finale.

    L'essentiel du boulot n'est pas là.
    Il faut déjà vérifier que ce paramétrage sur NLS_SORT et NLS_COMP a bien les effets attendus sur les recherches. Ca doit marcher non seulement avec un critère d'égalité (WHERE ... =), mais aussi avec n'importe quel autre opérateur de comparaison : > <> BETWEEN LIKE.

    Mais surtout, vous allez devoir revoir l'indexation de toutes vos colonnes texte, car NLS_COMP=LINGUISTIC rendra vos index standard inopérants.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    SQL> select * from scott.emp where ename='SCoTT';
     
    aucune ligne sélectionnée
     
     
    Plan d'exécution
    ----------------------------------------------------------
    Plan hash value: 48385638
     
    -----------------------------------------------------------------------------------------
    | Id  | Operation                   | Name      | Rows  | Bytes | Cost (%CPU)| Time     |
    -----------------------------------------------------------------------------------------
    |   0 | SELECT STATEMENT            |           |     1 |    38 |     2   (0)| 00:00:01 |
    |   1 |  TABLE ACCESS BY INDEX ROWID| EMP       |     1 |    38 |     2   (0)| 00:00:01 |
    |*  2 |   INDEX RANGE SCAN          | IND_ENAME |     1 |       |     1   (0)| 00:00:01 |
    -----------------------------------------------------------------------------------------
     
    Predicate Information (identified by operation id):
    ---------------------------------------------------
       2 - access("ENAME"='SCoTT')
     
     
    SQL> alter session set nls_comp=linguistic;
    Session modifiée.
     
    SQL>
    SQL> select * from scott.emp where ename='SCoTT';
    aucune ligne sélectionnée
     
     
    Plan d'exécution
    ----------------------------------------------------------
    Plan hash value: 3956160932
     
    --------------------------------------------------------------------------
    | Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
    --------------------------------------------------------------------------
    |   0 | SELECT STATEMENT  |      |     1 |    38 |     3   (0)| 00:00:01 |
    |*  1 |  TABLE ACCESS FULL| EMP  |     1 |    38 |     3   (0)| 00:00:01 |
    --------------------------------------------------------------------------
     
    Predicate Information (identified by operation id):
    ---------------------------------------------------
       1 - filter(NLSSORT("ENAME",'nls_sort=''FRENCH''')=HEXTORAW('691E5A6E6E00010102010100') )
    Vous devrez donc créer des index fonctionnels sur les colonnes appropriées.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
    SQL> create index NLS_ENAME on scott.emp(nlssort(ename, 'nls_sort=binary_ci'));
     
    Index créé.
     
    SQL> select * from scott.emp where ename='SCoTT';
     
         EMPNO ENAME      JOB              MGR HIREDATE        SAL       COMM     DEPTNO
    ---------- ---------- --------- ---------- -------- ---------- ---------- ----------
          7788 SCOTT      ANALYST         7566 19/04/87       3000                    20
     
     
    Plan d'exécution
    ----------------------------------------------------------
    Plan hash value: 2230589022
     
    -----------------------------------------------------------------------------------------
    | Id  | Operation                   | Name      | Rows  | Bytes | Cost (%CPU)| Time     |
    -----------------------------------------------------------------------------------------
    |   0 | SELECT STATEMENT            |           |     1 |    38 |     2   (0)| 00:00:01 |
    |   1 |  TABLE ACCESS BY INDEX ROWID| EMP       |     1 |    38 |     2   (0)| 00:00:01 |
    |*  2 |   INDEX RANGE SCAN          | NLS_ENAME |     1 |       |     1   (0)| 00:00:01 |
    -----------------------------------------------------------------------------------------
     
    Predicate Information (identified by operation id):
    ---------------------------------------------------
     
       2 - access(NLSSORT("ENAME",'nls_sort=''BINARY_CI''')=HEXTORAW('73636F747400'))
    Eh oui, les recherches sans tenir compte de la casse ont de très grosses conséquences, ça n'est pas un simple paramétrage qu'on fait en un claquement de doigts.
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  7. #27
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 183
    Points : 36
    Points
    36
    Par défaut
    Merci pour vos aides ! Je vais étudier cela de près !

    Sinon, comment peut on gérer ou plutôt contourner le fait que pour Oracle, une chaine de caractère vide "" soit NULL ? J'estime que si j'insère "", je dois avoir "" (comme chez MySQL ou SQL Serveur) ... car sinon, quand je récupère la donnée et que je l'affiche, j'affiche NULL et pas ""

    Merci

  8. #28
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Points : 5 307
    Points
    5 307
    Par défaut
    Citation Envoyé par mnitu Voir le message
    C'est dèjà mieux. Reste à voir que est-ce que c'est exactement votre pool de connexion mais il est très probable que votre pool de connexion reste connecté tout le temps à la base. Or il suffit que l'alter se fait seulement une fois, après l'ouverture de la connexion à la base, par le pool voir un trigger dans la base.
    Mais, avez vous répondu à la question que est-ce que vous voulez obtenir et pourquoi utiliser Upper etc. n'est pas satisfaisant ?
    Il y a une différence entre connexion et session.
    Dans un pool de connexion Oracle, la connexion physique est effectivement conservée mais pas la session.
    Donc chaque récupération d'un connexion fait systématiquement l'objet d'un logon et le trigger sera déclenché pour une même connexion chaque fois l'on la récupère du pool.
    Par contre, si c'est un pool de session, la c'est différent...
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

  9. #29
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Merci Vincent pour ces précisions.

  10. #30
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 183
    Points : 36
    Points
    36
    Par défaut
    Merci pour ces précisions importantes !

    Oracle ne permet tout simplement pas de modifier ces paramétrages en dure une bonne fois pour toute ?

  11. #31
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252

  12. #32
    Membre habitué
    Inscrit en
    Mai 2010
    Messages
    107
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 107
    Points : 132
    Points
    132
    Par défaut
    Edite ton fichier init.ora pour définir/modifier les paramètres globaux de ta base de données.

Discussions similaires

  1. Insérer une chaine de caractères vide dans un vecteur
    Par ebenmous dans le forum Débuter avec Java
    Réponses: 1
    Dernier message: 28/06/2011, 21h55
  2. Ma DLL retourne une chaine de caractère vide.
    Par alain8550 dans le forum ASP.NET
    Réponses: 2
    Dernier message: 31/01/2010, 16h28
  3. Insertion chaine de caractére vide
    Par missd12 dans le forum SQL
    Réponses: 9
    Dernier message: 01/12/2009, 15h51
  4. Réponses: 2
    Dernier message: 07/11/2007, 08h44
  5. Chaine de caractére vide
    Par etranger dans le forum Delphi
    Réponses: 3
    Dernier message: 25/05/2006, 14h45

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo