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 :

#ERREUR# Enregistrement Image dans base de données MySql


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Homme Profil pro
    Inscrit en
    Septembre 2008
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8
    Par défaut #ERREUR# Enregistrement Image dans base de données MySql
    Bonjour tous le monde.

    Enfin, bonsoir.

    Ma config: VS2010
    MySql Server


    Ca fait quelques heures que je suis sur le problème suivant.

    Dans mon applic, j'ai un pictureBox que je remplis depuis une table qui ce trouve dans ma base MySql. Le Champ est de type BLOB. Si j'enregistre la valeure directement avec l'outil d'administration MySql, je n'ai aucuns soucis pour afficher mon image. Par contre, si j'enregistre par l'intermédiaire de mon applic, les données binaires ne sont pas complètes.

    Quand j'enregistre, ma valeure Byte[] vaut 21009 (Image de test).
    Si je passe via l'outil d'admin, au moment de la lecture, cette valeure est identique dans mon applic et, mon image s'affiche.
    Si j'enregistre via mon applic, au moment le la lecture, cette valeure est Byte[] vaut{6} et, logique que j'ai une erreur.

    Après plusieurs essais, je constate que dans ma requete de mise à jour, la valeure est correct mais, il semble que surement un paramètre ne soit pas correct.

    Je joint un bout de code, plus très propre car énorméments de test mais, j'espère qu'avec cela une solution sera trouvée

    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
    public static Boolean Record_Img(String SqlStr,Byte[] Parametre)
            {
     
    //SqlStr = Chaine Sql
    //Parametre = Valeure binaire à enregistrer
     
    //Enregistrement DB
                    OdbcCommand MyComm1 = new OdbcCommand(SqlStr, Params.My_Connection);
                    OdbcParameter prm = new OdbcParameter();
                    prm.ParameterName = "?Image";
                    prm.OdbcType = OdbcType.VarBinary;
                    prm.Direction = ParameterDirection.Input;
                    prm.SourceVersion = DataRowVersion.Current;
                    prm.IsNullable = true;
                    prm.Size = Parametre.Length;
                    prm.Value = Parametre;
     
                    MyComm1.Parameters.Add(prm);
                    MyComm1.ExecuteNonQuery();
                    MyComm1 = null;
                    return true;
    }
    J'ai essayé, énorméments de changements mais, c'est toujours identique.
    Problème peut-être d'ailleur?

    Déjà un grand merci d'avance.

  2. #2
    Modérateur
    Avatar de DotNetMatt
    Homme Profil pro
    CTO
    Inscrit en
    Février 2010
    Messages
    3 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : CTO
    Secteur : Finance

    Informations forums :
    Inscription : Février 2010
    Messages : 3 611
    Billets dans le blog
    3
    Par défaut
    Stocker les images dans une base de données est une mauvaise pratique, il vaut mieux y stocker les méta données (chemin, format, etc.) et avoir les images sur le file system directement.

    A part ça, pour ton problème, peux-tu poster le code qui te permet de récupérer le tableau de byte que tu passes en paramètre à la méthode Record_Img ?
    Less Is More
    Pensez à utiliser les boutons , et les balises code
    Desole pour l'absence d'accents, clavier US oblige
    Celui qui pense qu'un professionnel coute cher n'a aucune idee de ce que peut lui couter un incompetent.

  3. #3
    Membre habitué
    Homme Profil pro
    Inscrit en
    Septembre 2008
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8
    Par défaut
    Citation Envoyé par DotNetMatt Voir le message
    Stocker les images dans une base de données est une mauvaise pratique, il vaut mieux y stocker les méta données (chemin, format, etc.) et avoir les images sur le file system directement.

    A part ça, pour ton problème, peux-tu poster le code qui te permet de récupérer le tableau de byte que tu passes en paramètre à la méthode Record_Img ?


    Déjà, un grand merci pour la réponse.

    Pour ma part, vu mon applic, pour quelques images, il m'est plus facile de les stocker dans la base. La grande majorité, je ne stock que le fichier.

    Comme demandé, voici le code pour record_img:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Byte[] Img = new Byte[0];
    Img= SetImg(pictureLogo.Image);
    String img;
    if (Img==null){img="null";}else{img="'?Image'";}
    SqlStr = "UPDATE bd_societes SET WHERE (bd_societes.idbd_societes=" + dataGridView1.CurrentRow.Cells["Col_ID"].Value + ");";
    Cl_Tools.Cl_Main.Record_Img(SqlStr,Img, true)

    Et voici aussi le "SetImg()"
    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
    26
    27
    28
    29
    30
     
    public static Byte[] SetImg(Image img)
            {
                try
                {
                    if (img != null)
                    {
                        MemoryStream ms = new MemoryStream();
                        img.Save(ms, ImageFormat.Jpeg);
     
                        //Read from MemoryStream into Byte array.
                        Byte[] bytBLOBData = new Byte[ms.Length];
                        ms.Position = 0;
                        ms.Read(bytBLOBData, 0, Convert.ToInt32(ms.Length));
     
                        ms.Close();
     
                        return bytBLOBData;
                    }
                    else
                    {
                        return null;
                    }
                }
                catch (Exception ex)
                {
                    AjoutLog("Impossible de traiter l'image \r\n \r\n " + ex.Message, "402", 402, 2, true);
                    MessageBox.Show("Impossible de traiter l'image \r\n \r\n " + ex.Message, "Erreur", MessageBoxButtons.OK, MessageBoxIcon.Error);
                    return null;
                }
    Quand je suis en débogage, la valeur retournée et, qui ce trouve dans la request sql (SqlStr) est juste.

    Merci d'avance

Discussions similaires

  1. [MySQL] enregistrer une plage horaire dans base de données mysql
    Par johan0510 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 25/08/2010, 16h18
  2. Enregistrer image dans base de donnée
    Par sat83 dans le forum C++Builder
    Réponses: 3
    Dernier message: 09/09/2009, 10h21
  3. Réponses: 3
    Dernier message: 19/09/2006, 15h36
  4. Réponses: 6
    Dernier message: 09/06/2006, 12h17
  5. [VB.NET]Champ image dans base de donnée access
    Par dankes dans le forum Windows Forms
    Réponses: 10
    Dernier message: 06/10/2005, 15h31

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