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

C# Discussion :

Problème lecture types composés (+ SPATIAL) avec ODBC ORACLE


Sujet :

C#

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 33
    Points : 23
    Points
    23
    Par défaut Problème lecture types composés (+ SPATIAL) avec ODBC ORACLE
    Bonjour,

    j'ai un problème pour utiliser le driver ODBC d'Oracle sur des objets complexes en C#.

    A la base, je veux lire des objets Oracle Spatial (SDO_GEOMETRY).

    J'arrive à accéder aux éléments simples de l'objet (SDO_GTYPE) mais je n'arrive pas à lire les sous objets SDO_ELEM_INFO et SDO_ORDINATES qui sont de types SDO_ELEM_INFO_ARRAY et SDO_ORDINATE_ARRAY (qui eux mêmes sont des alias pour VARRAY (1048576) of NUMBER).

    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
     
               string queryString = "select l.geometrie.SDO_ELEM_INFO from lignes l;";
     
                using (OdbcConnection connection = new OdbcConnection(connectString))
                {
                    connection.Open();
     
                    try
                    {
                        OdbcCommand command = new OdbcCommand(queryString);
                        command.Connection = connection;
                        command.CommandType = System.Data.CommandType.Text;
     
                        OdbcDataReader reader = command.ExecuteReader();
     
                        while (reader.Read())
                        {
                            decimal[] d = (decimal[])reader.GetValue(0);
                        }
                    }
                    catch
                    {
     
                    }
                }
    Lorsque j'execute la fonction read j'obtiens l'exception suivante :
    "ERROR [HY000] [Oracle][ODBC][Ora]ORA-24359: OCIDefineObject n'a pas été appelé pour un type d'objet ou une référence"
    Ce qui est très étonnant, c'est que lorsque j'utilise une autre méthode pour lire Oracle ( les objets OracleConnection, OracleCommand et OracleDataReader de la librairie Oracle.DataAccess ), ce même code marche.

    Néanmoins je préfèrerais utiliser ODBC plutôt que le client de la DLL Oracle.DataAccess.

    D'une manière générale, j'aimerais savoir comment lire les objets "complexes" avec ODBC.

    Je vous remercie par avance pour votre aide.

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par losformen Voir le message
    Néanmoins je préfèrerais utiliser ODBC plutôt que le client de la DLL Oracle.DataAccess.
    Pourquoi ?
    ODBC est moins performant et moins compatible que n'importe quel provider ADO.NET spécifique. Quand tu as un ADO.NET spécifique, c'est presque toujours mieux que de passer par ODBC (je dis "presque" au cas où ODBC aurait des avantages qui m'échappent dans certaines situations, mais là comme ça je n'ai aucun exemple...)

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 33
    Points : 23
    Points
    23
    Par défaut
    Je trouve que ODBC est plus simple à configurer.
    Et surtout j'aimerais comprendre.
    Le pilote que j'utilise pour ODBC est celui d'Oracle, que j'ai obtenu en installant le toolkit qui contenait aussi les librairies pour C#.
    Pourquoi le pilote fournit par Oracle pour ODBC n'offre t il pas les mêmes fonctions que que le provider ADO.Net ?

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par losformen Voir le message
    Pourquoi le pilote fournit par Oracle pour ODBC n'offre t il pas les mêmes fonctions que que le provider ADO.Net ?
    A ma connaissance, c'est dû à des limitations techniques ; ODBC est un système trop générique pour pouvoir prendre en compte toutes les spécificités de tel ou tel SGBD.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Problème lecture fichier en redirection avec foreach
    Par nicnictout dans le forum Langage
    Réponses: 25
    Dernier message: 07/01/2011, 16h11
  2. Problème de type d'objet avec xmlbeans
    Par nicocolt dans le forum Format d'échange (XML, JSON...)
    Réponses: 0
    Dernier message: 31/08/2009, 15h10
  3. Problème de type de variable avec la fonction find
    Par Sarune dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 12/11/2008, 17h06
  4. [Généralités] Lenteur requete avec ODBC (Oracle)
    Par lars528 dans le forum Access
    Réponses: 12
    Dernier message: 30/11/2006, 09h24
  5. Réponses: 4
    Dernier message: 09/05/2006, 10h29

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