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

Windows Forms Discussion :

[C#] Comment enregistrer une image dans une tables access ?


Sujet :

Windows Forms

  1. #1
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 74

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut [C#] Comment enregistrer une image dans une tables access ?
    Bonjour

    j ai une form et une classe (ou sont crées mes datasets et objtes pour sql)

    depuis la form je passe mon image a la classe

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     _AjoutFilm.Fi_Jacquette = pctBoxCover.Image;
    dans ma classe je récupere l image comme ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
            private Image fi_Jacquette;
     
            public Image Fi_Jacquette
            {
                get { return fi_Jacquette; }
                set { fi_Jacquette = value; }
            }
    Puis dans ma classe je veux inserer des données, et donc mon image dans une table

    je fais ca

    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
    31
    32
                String _strSql = "INSERT INTO Films ( FI_Num, FI_Titre, FI_Annee_sortie, FI_Date_Parution, FI_Date_Achat, FI_Duree, FI_Zone, FI_Realisateur, FI_Studio, FI_Genre, FI_Resume, FI_Modif_Date, FI_Modif_Qui, FI_Jacquette)"
                                         + " VALUES ( @FI_Num, @FI_Titre, @FI_Annee_sortie, @FI_Date_Parution, @FI_Date_Achat, @FI_Duree, @FI_Zone, @FI_Realisateur, @FI_Studio, @FI_Genre, @FI_Resume, @FI_Modif_Date, @FI_Modif_Qui, @FI_Jacquette);";
                Int32 RetourValeurInsertion = 0;
     
                try
                {
                    using (DbConnection cn = new OleDbConnection(methode.doConnectionString()))
                    {
                        using (DbCommand cmd = new OleDbCommand(_strSql, (OleDbConnection)cn))
                        {
                            cmd.CommandType = CommandType.Text;
     
    .....
     
                            DbParameter FI_Jacquette = new OleDbParameter("@FI_Jacquette", OleDbType.Binary);
                            FI_Jacquette.Value = fi_Jacquette;
                            cmd.Parameters.Add(FI_Jacquette);
     
                            cn.Open();
                            cmd.ExecuteNonQuery();
     
                            cmd.CommandText = "SELECT @@IDENTITY";
                            RetourValeurInsertion = (Int32)cmd.ExecuteScalar();
     
                            cn.Close();
     
                            return RetourValeurInsertion;
                        }
                    }
                }
                catch (Exception e)
                {
    tou marche bien si je mets la patie image en commentaire sinon j ai une erreur

    + $exception {"Échec de la conversion de la valeur de paramètre d'un Bitmap en un Byte[]."} System.Exception {System.InvalidCastException}
    Qui peut m aider car ca fait 1 mois que je butes la dessus

    merci
    Philippe Cazaux-Moutou
    C#
    Delphi
    Windev

    Guadeloupe

    www.ancestrologie.net/fr

  2. #2
    Membre éprouvé Avatar de guitoux1
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    1 011
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 1 011
    Points : 1 256
    Points
    1 256
    Par défaut
    Tout est dans le message d'erreur :

    exception {"Échec de la conversion de la valeur de paramètre d'un Bitmap en un Byte[]."} System.Exception {System.InvalidCastException}
    Il faut que tu passge ton Image au format byte[] tout simplement

  3. #3
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 74

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut
    Je veux bien, mais pa rapport a mon code comment faire ?
    Philippe Cazaux-Moutou
    C#
    Delphi
    Windev

    Guadeloupe

    www.ancestrologie.net/fr

  4. #4
    Rédacteur
    Avatar de The_badger_man
    Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2005
    Messages
    2 745
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 745
    Points : 8 538
    Points
    8 538
    Par défaut
    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
     
    try
    {
    // Tableau d'octets representant l'image au format jpeg
    MemoryStream mstImage  = new MemoryStream();
    //pbxImage est une picture box
    pbxImage.Image.Save(mstImage,System.Drawing.Imaging.ImageFormat.Jpeg);
    Byte[] bytImage = mstImage.GetBuffer();
     
    // Connexion à la base 
    OleDbConnection cnxTestAccessImage = new OleDbConnection(strCnx);
    cnxTestAccessImage.Open();
     
    // Insere l'image dans la base
    OleDbCommand cmdTestAccessImage = new OleDbCommand("INSERT INTO IMAGES([Image], [Commentaire]) VALUES (?, ?)", cnxTestAccessImage);
    cmdTestAccessImage.Parameters.Add(new OleDbParameter("Image", OleDbType.VarBinary, bytImage.Length, 
        ParameterDirection.Input, false, 0, 0, null,DataRowVersion.Current, bytImage));
    cmdTestAccessImage.Parameters.Add(new OleDbParameter("Commentaire", System.Data.OleDb.OleDbType.VarWChar, 50, 
       ParameterDirection.Input, false, 0, 0, null,DataRowVersion.Current, txtCommentaire.Text));
     
    cmdTestAccessImage.ExecuteNonQuery();
    cnxTestAccessImage.Close();									
    }
     
    catch(Exception ex)
    {
            MessageBox.Show (string.Concat("Erreur: ", ex.Message));
    }
    Les règles du forum
    Le trio magique : FAQ + Cours + fonction rechercher
    Mes articles
    Pas de questions par messages privés svp

    Software is never finished, only abandoned.

  5. #5
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 74

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut
    BadgerMan

    je viens d essayer d adapter ton code, mais hélas etant débutant en C#, j ai pas résussi

    je rappele, que mon picturebox est sur ma form et que le reste est dans une classe et que je passe l image comme ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    _AjoutFilm.Fi_Jacquette = pctBoxCover.Image;
    et que je réceptionne l image dans la classe comme ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
            private Image fi_Jacquette;
     
            public Image Fi_Jacquette
            {
                get { return fi_Jacquette; }
                set { fi_Jacquette = value; }
            }
    Philippe Cazaux-Moutou
    C#
    Delphi
    Windev

    Guadeloupe

    www.ancestrologie.net/fr

  6. #6
    Rédacteur
    Avatar de The_badger_man
    Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2005
    Messages
    2 745
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 745
    Points : 8 538
    Points
    8 538
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    // Tableau d'octets representant l'image au format jpeg
    MemoryStream mstImage  = new MemoryStream();
    //pbxImage est une picture box
    Fi_Jacquette.Save(mstImage,System.Drawing.Imaging.ImageFormat.Jpeg);
    Byte[] bytImage = mstImage.GetBuffer();

    là tu récupère ton image transformée en tableau de bytes dans byImage.
    Les règles du forum
    Le trio magique : FAQ + Cours + fonction rechercher
    Mes articles
    Pas de questions par messages privés svp

    Software is never finished, only abandoned.

  7. #7
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 74

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut
    Bon

    en faisant ca j ai plus de pb de compilation

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
                            MemoryStream mstImage = new MemoryStream();
     
                            Fi_Jacquette.Save(mstImage, System.Drawing.Imaging.ImageFormat.Jpeg);
                            Byte[] bytImage = mstImage.GetBuffer();
     
                            cmd.Parameters.Add(new OleDbParameter("@FI_Jacquette", OleDbType.VarBinary, bytImage.Length,
                                                  ParameterDirection.Input, false, 0, 0, null, DataRowVersion.Current, bytImage));
    mais ca plante la

    avec comme message

    + $exception {"Type de données incompatible dans l'expression du critère."} System.Exception {System.Data.OleDb.OleDbException}
    que faire ?
    Philippe Cazaux-Moutou
    C#
    Delphi
    Windev

    Guadeloupe

    www.ancestrologie.net/fr

  8. #8
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 74

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut
    C est bon CA MARCHE

    j ai mis le param Jacquette à la fin et la c est bon

    Merci a tous
    Philippe Cazaux-Moutou
    C#
    Delphi
    Windev

    Guadeloupe

    www.ancestrologie.net/fr

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

Discussions similaires

  1. [Débutant] Manipulation d'images : intégrer une image dans une image
    Par noscollections dans le forum VB.NET
    Réponses: 2
    Dernier message: 17/10/2014, 11h51
  2. Réponses: 2
    Dernier message: 27/10/2010, 20h38
  3. [PostgreSQL] Comment enregistrer des images dans une bd
    Par inessahal dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 13/06/2008, 15h57
  4. Réponses: 3
    Dernier message: 30/10/2006, 11h21
  5. Insérer une légende dans une image avec une police plus petite
    Par Paulinho dans le forum Tableaux - Graphiques - Images - Flottants
    Réponses: 3
    Dernier message: 29/04/2006, 14h19

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