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 :

Pb de suvegarde d'un blob xml dans une base oracle


Sujet :

SQL Oracle

  1. #1
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    107
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 107
    Par défaut Pb de suvegarde d'un blob xml dans une base oracle
    Bonjour,

    j'ai un soft en java qui a pour role d'instaurer des fichiers xml sous format blob dans une base oracle.
    Mon pb est quand j'essaye de lire ce blob xml de la base pour verifer qu'il a ete bien sauvegarde je trouve cette erreur: "An invalid character was found in text content. Error processing resource "des que le champs details quantients deux ou trois paragraphes.

    mon fichier xml a la structure suivante
    <latestnews>
    <newshead>
    <xmldate>... </xmldate>
    <topstory>...</topstory>
    <details>...</details>
    </newshead>
    </latestnews>
    le champ details contient des informations sportives. et l'errer se produit quand jemet plus que deux paragraphes !!

    je lis ce blob a partir de la base de donne oracle avec le soft suivant:
    try
    {
    Class.forName("oracle.jdbc.driver.OracleDriver");
    con = DriverManager.getConnection(
    "jdbc:oracle:thin:@IpAddress:1521:orcl1",
    "user","pwd");

    /*File monImagel = new File("E:\\JDevloper\\jdev\\mywork\\JcWebAppli\\JcDataBase\\public_html/events.xml");
    FileOutputStream ostreamImage = new FileOutputStream(monImagel);*/

    try
    {
    PreparedStatement pss = con.prepareStatement("select xmlfile from latestevents where id_event=?");

    try
    {
    pss.setInt(1,3);
    ResultSet rss = pss.executeQuery();
    rss.next();

    Blob blob = rss.getBlob("xmlfile");
    try
    {
    InputStream istreamImagel = blob.getBinaryStream();
    //response.reset();
    byte[] buffer = new byte[1024];
    int length = 0;

    while(((length = istreamImagel.read(buffer)) != -1))
    {
    //ostreamImage.write(buffer, 0, length);
    response.getOutputStream().write(buffer,0,length);
    }
    response.flushBuffer();
    }
    catch(Exception e)
    {
    out.println("ERROR1: "+e);
    }
    finally
    {
    rss.close();
    }
    }
    catch(Exception e)
    {
    out.println("ERROR2: "+e);
    }
    finally
    {
    pss.close();
    }
    }
    catch(Exception e)
    {
    out.println("ERROR3: "+e);
    }
    finally
    {
    //ostreamImage.close();
    }
    }
    catch(ClassNotFoundException e)
    {
    out.println("<p>Could not load database driver:"
    +e.getMessage()+"</p>");
    }
    catch(SQLException e)
    {
    out.println("<p>SQLException caught:"
    +e.getMessage()+"</p>");
    }
    finally
    {//close connection no matter what
    try
    {
    if(con!=null)
    {
    con.close();
    }
    }catch(SQLException ignored){}
    }
    je suis vraiement dans un grand pb. Il faut que j'installe mes sources dans le nouveau serveur et il y a des choses qui ne marchent pas !!!

  2. #2
    Membre chevronné Avatar de Wurlitzer
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 469
    Par défaut
    Pour le code Java, je ne pense pas que tu sois dans le bon Forum.

    De quels outils disposes tu pour acceder à ta base en direct (TOAD, SQL PLus ?)

    As tu essayer de lire ton xml avec ces outils et de le sauvegarder au format texte pour l'ouvrir avec un outil qui te le validera (Genre XMLSpy ou meme simplement IE). Juste histoire de verifier que xml est bien formé, qu'il ne contient pas des pas exemple un caractère < dans le contenu d'un paragraphe.

    Tous cela pour te dire qu'avant de mettre en cause le code java, je verifirais déjà les données.

    Hope this helps

  3. #3
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    107
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 107
    Par défaut
    en fait j'arrive a ouvrir le fichier xml avec IE !!
    et j'ai remarque qu'en travaillant avec Oracle Jdeveloper tout marche tres bien !!
    par contre contre quand je compile mon code java, et je met le .class dans Apache Jserv ca marche pour certains fichiers xml et pas pour d'autres !!
    et en plus dans la base de donnee oracle j'ai remarque qu'il me sauve le fichier xml dans le champ image et le .jpg dans le champ xmlfile de la table c'est a dire qu'il inverse les deux champs !! et cela n'arrive pas avec Jdeveloper !

Discussions similaires

  1. Application Java web qui permet d'intégrer des données XML dans une base Oracle
    Par honesttrick dans le forum Développement Web en Java
    Réponses: 3
    Dernier message: 22/10/2014, 10h50
  2. Problème création de schéma XML dans une base oracle
    Par el_conkeror dans le forum Oracle
    Réponses: 7
    Dernier message: 19/03/2010, 15h54
  3. Réponses: 0
    Dernier message: 07/07/2008, 20h42
  4. importer des données XML dans une base Oracle 9
    Par lanfeustdetroll dans le forum JDBC
    Réponses: 3
    Dernier message: 19/07/2007, 00h09
  5. Champs de type XML dans une base de données
    Par Flocodoupoil dans le forum Décisions SGBD
    Réponses: 3
    Dernier message: 07/07/2004, 18h57

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