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

Oracle Discussion :

[V10/XE] chaine vides vs nulles :cry:


Sujet :

Oracle

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Août 2006
    Messages
    243
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 243
    Points : 328
    Points
    328
    Par défaut [V10/XE] chaine vides vs nulles :cry:
    Bonjour,

    Comme beaucoup, je suis confronté à la manière qu'a Oracle de remplacer les chaînes vides par des chaînes nulles à l'enregistrement () et après avoir écumé une (petite, faut pas rêver cry partie du net et cherché ici, je pose quand même la question dès fois que depuis quelqu'un aurait mis la main sur un moyen de contourner la chose.

    Mon problème est le suivant (hors considération philosophiques sur qui à raison ou tord entre Oracle et les autres) : j'ai une application développée pour SQL Server à faire tourner avec Oracle et bien sûr :
    1) le problème ne s'est jamais posé avec Ms
    2) il n'y a pas une manière standard (pour l'appli) de lire/écrire dans la base: 'composants' d'accès aux données, requêtes SQL (dynamiques ou non) dans le code...:
    3) pas mal de champs xChar en 'NOT NULL' et dont la présence ou non d'espaces peut avoir ou non une signification fonctionnelle...

    Donc pour finir, y-a-t-il un moyen de forcer (ou contourner) Oracle (v10 et XE) à travailler comme les copains (via un alter session ou autre) (j'ai bien pensé à des triggers qui vérifieraient/mettrais des espaces ou autres à la volée, mais comme ça ne résoud pas le problème de la lecture du 3)....) ?

    Désolé de remettre cà sur le tapis

  2. #2
    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
    Bonjour

    1) le problème ne s'est jamais posé avec Ms
    Tant mieux, mais vous avez juste oublié de dire en quoi consiste ce problème !!!

    Vous cherchez un moyen pour qu'Oracle fasse la distinction entre chaîne vide et chaîne nulle, c'est ça ?
    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

  3. #3
    Membre éprouvé
    Inscrit en
    Avril 2006
    Messages
    1 024
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 1 024
    Points : 1 294
    Points
    1 294
    Par défaut
    Il faut aussi préciser si le problème concerne le type "char" ou le type "varchar", car les comportement sont complètement différent.

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Août 2006
    Messages
    243
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 243
    Points : 328
    Points
    328
    Par défaut
    Citation Envoyé par Pomalaix
    Bonjour
    Vous cherchez un moyen pour qu'Oracle fasse la distinction entre chaîne vide et chaîne nulle, c'est ça ?
    Presque : qu'il ne remplace plus une chaine vide par une nulle à l'enregistrement (pour les varchar de mémoire [je ne suis pas au taf ). Je sais bien qu'il s'agit du fonctionnement normal d'Oracle mais je cherche un moyen de régler ce problème sans devoir éplucher/modifier plusieurs Mo de code et en espérant ne pas oublier un traitement dans un coin.

    ps : Désolé, je pensais avoir été clair mais comme ça fait un moment que je suis dedans, je suis devenu un peu mono-tâche .

  5. #5
    Membre éprouvé
    Inscrit en
    Avril 2006
    Messages
    1 024
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 1 024
    Points : 1 294
    Points
    1 294
    Par défaut
    En varchar, chaine vide et null, c'est la même chose. C'est vrai que c'est souvent génant, je ne pense pas qu'on puisse y changer grand chose. Je ne vois pas oracle modifier ça parcque ça ferait régresser tout un tas de trucs déja codé dans des versions précédentes. Cependant, si un simple paramètre permet d'agir dessus, ça m'interresse aussi

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Août 2006
    Messages
    243
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 243
    Points : 328
    Points
    328
    Par défaut
    Citation Envoyé par remi4444
    En varchar, chaine vide et null, c'est la même chose. C'est vrai que c'est souvent génant, je ne pense pas qu'on puisse y changer grand chose. Je ne vois pas oracle modifier ça parcque ça ferait régresser tout un tas de trucs déja codé dans des versions précédentes. Cependant, si un simple paramètre permet d'agir dessus, ça m'interresse aussi
    chaîne vide & null : vi mais l'appli fait la différence elle
    oracle modifier ça : oui et non vu que dans la doc, ils disent que ça pourraît changer - ils ont commencé à l'annoncer vers la v7 je crois . Ils ne sont pas obligés non plus de le coder (et je me doute que ça doit être loin d'être simple techniquement) en tant que fonctionnement standard. je verrais plutôt un paramétrage optionnel, au moins pendant quelques versions, histoire que les dev/dba en prennent l'habitude. M'enfin, c'est eux qui décideront au final

    en attendant, reste plus qu'a essayer de tester en croisant les doigts (va pas être facile en même temps).

Discussions similaires

  1. Meilleur moyen de remplacer une chaine vide par null
    Par ToniConti dans le forum Développement de jobs
    Réponses: 2
    Dernier message: 02/09/2013, 10h11
  2. DBparameter+convertir chaine vide en null
    Par tortuegenie dans le forum ASP.NET
    Réponses: 5
    Dernier message: 23/04/2008, 15h40
  3. Réponses: 2
    Dernier message: 06/02/2008, 22h14
  4. [8i]Chaine vide et NULL
    Par payenneville dans le forum Oracle
    Réponses: 10
    Dernier message: 26/01/2006, 18h55
  5. [BDD] renvoyer une chaine vide au lieu de null
    Par cmoulin dans le forum JDBC
    Réponses: 6
    Dernier message: 06/05/2004, 11h38

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