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

MS SQL Server Discussion :

[PHP/SQL] Problème d'insertion d'image dans SQL SERVEUR


Sujet :

MS SQL Server

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 27
    Points : 22
    Points
    22
    Par défaut [PHP/SQL] Problème d'insertion d'image dans SQL SERVEUR
    Bonjour

    Je cherche à insérer des images dans une BDD (SQL Serveur 2005)

    Voici la partie de mon code qui pose problème:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $img = file_get_contents ($_FILES['fic']['tmp_name']);
     
    $commande = "INSERT INTO image  VALUES ('".$img_nom."', '".$img_taille."','".$img_type."','','".addslashes($img)."') ";
     
    $resultat=odbc_exec($conn,$commande);
    et voici la réponse:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Warning: odbc_exec() [function.odbc-exec]: SQL error: [Microsoft][ODBC SQL Server Driver]Erreur de syntaxe ou violation d'accès, SQL state 37000 in SQLExecDirect in D:\exploitation_front\transfert.php on line 36
    Bref je ne comprends pas pourquoi je ne peux pas l'insérer. Je ne vois pas d'ou viens le problème
    Pour info j'ai mis comme type nvarchar(MAX) dans ma BDD.

    Par ailleurs si je passe par un $data = unpack("H*hex", $img);
    là j'arrive à insérer mon image en héxadécimal.

    Mais le problème c'est que je veux stocker sans la transformation pour pouvoir faire un file_put_contents ensuite.

    Voila merci d'avance!

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Il s'agit peut-être d'un problème d'accès au répertoire : le compte de service sous lequel s'exécute SQL Server n'a peut-être pas les droits d'accès au répertoire dans lequel sont stockées les images.

    Peut-être pouvez-vous utiliser ceci ?

    @++

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 27
    Points : 22
    Points
    22
    Par défaut
    Le problème c'est que je ne comprends pas pourquoi ce code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $img = file_get_contents ($_FILES['fic']['tmp_name']);
    			$data = unpack("H*hex", $img);
    			$commande = "INSERT INTO image  VALUES ('".$img_nom."', '".$img_taille."','".$img_type."','','".$data['hex']."') ";
     
    $resultat=odbc_exec($conn,$commande);
    fonctionne. Il n'y a plus de problème d'accès alors que dans le fond, rien n'a changé, si ce n'est que l'image a été converti en hexadécimale.


    Merci pour le lien! je vais y jeter un oeil, mais j'ai l'impression qu'il utilise le type blob qui n'existe pas sur sql serveur....

  4. #4
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Je ne connais rien à Php, vous aurez plus de chance en demandant sur le forum Php

    Dans le lien que je vous ai donné, j'utilise la primitive OPENROWSET, dont je me sers parfois pour stocker tout autant de petits fichiers son qu'image dans une colonne de type VARBINARY(MAX).

    BLOB signifiant Binary Large OBject, il s'applique donc au paramètre BLOB de la primitive OPENROWSET.
    On peut aussi utiliser CLOB si l'on souhaite récupérer du texte.

    @++

Discussions similaires

  1. [AC-2013] Problème d'insertion d'image dans un formulaire avec une macro
    Par DrizztUrden dans le forum Macros Access
    Réponses: 0
    Dernier message: 05/05/2014, 10h25
  2. Problème d'insertion d'images dans mon interface graphique
    Par nini_python dans le forum Tkinter
    Réponses: 8
    Dernier message: 03/08/2012, 20h59
  3. Problème d'insertion d'image dans un document latex (utilisant TeXnicCenter)
    Par Lyna77 dans le forum Tableaux - Graphiques - Images - Flottants
    Réponses: 5
    Dernier message: 22/04/2011, 09h29
  4. Problème d'insertion d'image dans un tableau
    Par aminos40 dans le forum Tableaux - Graphiques - Images - Flottants
    Réponses: 2
    Dernier message: 01/06/2007, 10h54
  5. Problème d'insertion d'image dans une fenêtre.
    Par Antigonos Ier Gonatas dans le forum Tkinter
    Réponses: 2
    Dernier message: 26/08/2006, 13h44

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