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

ASP Discussion :

ASP - Insertion fichier dans une BD Oracle


Sujet :

ASP

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    262
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 262
    Points : 230
    Points
    230
    Par défaut ASP - Insertion fichier dans une BD Oracle
    Bonjour,
    mon but est d'uploader un fichier (.jpg par exemple) dans une base oracle.
    Je travaille en ASP JS, mais mon code ne marche pas, il me sort une erreur [object error]:

    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
     
    var adOpenStatic=3;
    var adLockOptimistic=3;
    var cnxstr = proxy.XmlDataSource().selectSingleNode("CONNECTSTRING").text;
    var stream = Server.CreateObject("ADODB.stream");
    var pathFile = "c:\\image.jpg";
    stream.Open();
    stream.Type = 1
    stream.LoadFromFile(pathFile);
     
    var conn = Server.CreateObject("ADODB.CONNECTION");
    conn.Open(cnxstr);
     
    var rs = Server.CreateObject("ADODB.RECORDSET");
    conn.BeginTrans();
    conn.Execute("INSERT INTO SMGSZCONFINFO (UIDSZCONFINFO, UIDNETWORKCONF, VALIDATIONDATE, PROFIL, CONFCOMMENT, CONFFILE )  VALUES (   ( SELECT CASE WHEN MAX(UIDSZCONFINFO)IS NULL THEN 1 ELSE MAX(UIDSZCONFINFO)+1 END FROM SMGSZCONFINFO ) , (SELECT UIDNETWORKCONF FROM SMGNETWORKCONF),  '03/07/2008', 'TOTO', 'MON COMMENT',  empty_blob())");
    rs.Open ("SELECT CONFFILE FROM SMGSZCONFINFO WHERE UIDSZCONFINFO = ( SELECT MAX( UIDSZCONFINFO) FROM SMGSZCONFINFO )", conn, adOpenStatic, adLockOptimistic);
     
    rs.Fields("CONFFILE").AppendChunk(stream.Read()); 
    rs.Update();
    rs.Close();  
    conn.CommitTrans();
    quelqu'un a peut-etre une idee ?

  2. #2
    Membre actif
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    262
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 262
    Points : 230
    Points
    230
    Par défaut
    Ca plante sur le rs.Update();

    il me dit : ODBC Driver not capable

  3. #3
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Bonjour,

    La gestion d'images dans une base de données, c'est galère.

    Perso, je stocke le nom complet (Chemin + nom de l'image) et je n'ai aucun problème.

  4. #4
    Membre actif
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    262
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 262
    Points : 230
    Points
    230
    Par défaut
    J'ai resolu mon probleme.
    J'ai remplace ces bouts de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ( SELECT MAX( UIDSZCONFINFO) FROM SMGSZCONFINFO )
    par un chiffre, et ca marche.
    Apparemment je ne peut pas faire la requete du MAX dans mon autre requete, c'est vraiment bizarre quand meme.

    Merci.

  5. #5
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 512
    Points
    9 512
    Par défaut
    Salut,

    Quand on fait une insertion en base, pour récupérer l'id généré il suffit de faire un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "INSERT INTO ...; SELECT SCOPE_IDENTITY"
    http://www.developpez.net/forums/showthread.php?t=18007

    A+

Discussions similaires

  1. Bulk insert plusieurs fichiers dans une table (sgbd oracle) avec TOS
    Par fetano dans le forum Développement de jobs
    Réponses: 0
    Dernier message: 30/07/2014, 22h37
  2. insertion fichier dans une base de données MYSQL
    Par Globolite dans le forum Requêtes
    Réponses: 5
    Dernier message: 23/01/2013, 18h15
  3. [ODBC] Insertion d'un fichier dans une base oracle 8i via ODBC
    Par garfield_fr dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 09/12/2010, 09h58
  4. Insertion des fichiers pdf dans une base oracle
    Par arezki76 dans le forum SQL
    Réponses: 2
    Dernier message: 20/07/2007, 16h39
  5. Optimisation d'une insertion dans une BD Oracle
    Par Hamma_TUN dans le forum Oracle
    Réponses: 5
    Dernier message: 13/07/2006, 10h55

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