Storing and Retrieving Images from SQL Serve

系统 2120 0

原文  Storing and Retrieving Images from SQL Server using Microsoft .NET

Introduction

This article is about storing and retrieving images from database in Microsoft .NET using C#.

Tools Used

  • SQL Server 2000
  • Microsoft .NET Version 1.1
  • C# (Windows Forms based application)

Storing Images

  1. Create a table in a SQL Server 2000 database which has at least one field of type  IMAGE .

    Here is the script I used:

              
                CREATE
              
              
                TABLE
              
               [dbo].[tblImgData] (
    
    
    
            [ID] [
              
                int
              
              ] 
              
                NOT
              
              
                NULL
              
               ,
    
    
    
            [Name] [
              
                varchar
              
              ] (
              
                50
              
              ) 
              
                COLLATE
              
               SQL_Latin1_General_CP1_CI_AS 
              
                NULL
              
               ,
    
    
    
            [Picture] [
              
                image
              
              ] 
              
                NULL
              
               
    
    
    
    ) 
              
                ON
              
               [
              
                PRIMARY
              
              ] TEXTIMAGE_ON [
              
                PRIMARY
              
              ]
            
  2. Actually  IMAGE  field is just holding the reference to the page containing the binary data so we have to convert our image into bytes.
    1. I used a file open dialog box to locate the file.
                    
                      this
                    
                    .openFileDialog1.ShowDialog(
                    
                      this
                    
                    );
      
      
                    
                      string
                    
                     strFn=this.openFileDialog1.FileName;
                  
    2. By using  FileInfo  class, I retrieved the file size:
                    FileInfo fiImage=new FileInfo(strFn);
                  
    3. Declare an array of that size.
                    
                      this
                    
                    .m_lImageFileLength=fiImage.Length;
      
      m_barrImg=new 
                    
                      byte
                    
                    [Convert.ToInt32(
                    
                      this
                    
                    .m_lImageFileLength)];
                  
    4. By using  FileStream  object, I filled the byte array.
                    FileStream fs=new FileStream(strFn,FileMode.Open, 
      
                        FileAccess.Read,FileShare.Read);
      
      
                    
                      int
                    
                     iBytesRead=fs.Read(m_barrImg,
                    
                      0
                    
                    ,
      
                     Convert.ToInt32(
                    
                      this
                    
                    .m_lImageFileLength));
      
      fs.Close();
                  

    Complete Load Image Code

              
                protected
              
              
                void
              
               LoadImage()
    
    {
    
        
              
                try
              
              
    
        {
    
            
              
                this
              
              .openFileDialog1.ShowDialog(
              
                this
              
              );
    
            
              
                string
              
               strFn=this.openFileDialog1.FileName;
    
            
              
                this
              
              .pictureBox1.Image=Image.FromFile(strFn);
    
            FileInfo fiImage=new FileInfo(strFn);
    
            
              
                this
              
              .m_lImageFileLength=fiImage.Length;
    
            FileStream fs=new FileStream(strFn,FileMode.Open, 
    
                              FileAccess.Read,FileShare.Read);
    
            m_barrImg=new 
              
                byte
              
              [Convert.ToInt32(
              
                this
              
              .m_lImageFileLength)];
    
            
              
                int
              
               iBytesRead = fs.Read(m_barrImg,
              
                0
              
              , 
    
                             Convert.ToInt32(
              
                this
              
              .m_lImageFileLength));
    
            fs.Close();
    
        }
    
        
              
                catch
              
              (Exception ex)
    
        {
    
            MessageBox.Show(ex.Message);
    
        }
    
    }
            
  3. Saving byte array data to database.
    1. Create command text to insert record.
                    
                      this
                    
                    .sqlCommand1.CommandText= 
      
        
                    
                      "
                    
                    
                      INSERT INTO tblImgData(ID,Name,Picture)"
                    
                     + 
      
        
                    
                      "
                    
                    
                       values(@ID,@Name,@Picture)"
                    
                    ;
                  
    2. Create parameters.
                    
                      this
                    
                    .sqlCommand1.Parameters.Add(
                    
                      "
                    
                    
                      @ID"
                    
                    ,
      
                 System.Data.SqlDbType.Int, 
                    
                      4
                    
                    );
      
      
                    
                      this
                    
                    .sqlCommand1.Parameters.Add(
                    
                      "
                    
                    
                      @Name"
                    
                    , 
      
                 System.Data.SqlDbType.VarChar, 
                    
                      50
                    
                    );
      
      
      
      
                    
                      this
                    
                    .sqlCommand1.Parameters.Add(
                    
                      "
                    
                    
                      @Picture"
                    
                    , 
      
                 System.Data.SqlDbType.Image);
                  

      Notice “ @Picture ” has “ SqlDbType.Image ” because it is of  IMAGE  type Field.

    3. Provide the value to the parameters.
                    
                      this
                    
                    .sqlCommand1.Parameters[
                    
                      "
                    
                    
                      @ID"
                    
                    ].Value=this.editID.Text;
      
      
                    
                      this
                    
                    .sqlCommand1.Parameters[
                    
                      "
                    
                    
                      @Name"
                    
                    ].Value=this.editName.Text;
      
      
      
      
                    
                      this
                    
                    .sqlCommand1.Parameters[
                    
                      "
                    
                    
                      @Picture"
                    
                    ].Value=this.m_barrImg;
                  

      this .m_barrImg ” is a byte array which we filled in the previous step.

    4. Now execute non-query for saving the record to the database.
                    
                      int
                    
                     iresult=this.sqlCommand1.ExecuteNonQuery();
                  

    Complete Save Image Code

              
                private
              
              
                void
              
               btnSave_Click(
              
                object
              
               sender, System.EventArgs e)
    
    {
    
        
              
                try
              
              
    
        {
    
            
              
                this
              
              .sqlConnection1.Open();
    
            
              
                if
              
               (sqlCommand1.Parameters.Count ==0 )
    
            {
    
                
              
                this
              
              .sqlCommand1.CommandText=
              
                "
              
              
                INSERT INTO tblImgData(ID,"
              
               + 
    
                               
              
                "
              
              
                 Name,Picture) values(@ID,@Name,@Picture)"
              
              ;
    
                
              
                this
              
              .sqlCommand1.Parameters.Add(
              
                "
              
              
                @ID"
              
              , 
    
                                 System.Data.SqlDbType.Int,
              
                4
              
              );
    
                
              
                this
              
              .sqlCommand1.Parameters.Add(
              
                "
              
              
                @Name"
              
              , 
    
                                 System.Data.SqlDbType.VarChar,
              
                50
              
              );
    
                
              
                this
              
              .sqlCommand1.Parameters.Add(
              
                "
              
              
                @Picture"
              
              , 
    
                                 System.Data.SqlDbType.Image);
    
            }
    
    
    
            
              
                this
              
              .sqlCommand1.Parameters[
              
                "
              
              
                @ID"
              
              ].Value=this.editID.Text;
    
            
              
                this
              
              .sqlCommand1.Parameters[
              
                "
              
              
                @Name"
              
              ].Value=this.editName.Text;
    
            
              
                this
              
              .sqlCommand1.Parameters[
              
                "
              
              
                @Picture"
              
              ].Value=this.m_barrImg;
    
    
    
            
              
                int
              
               iresult=this.sqlCommand1.ExecuteNonQuery();
    
            MessageBox.Show(Convert.ToString(iresult));
    
        }
    
        
              
                catch
              
              (Exception ex)
    
        {
    
            MessageBox.Show(ex.Message);
    
        }
    
        
              
                finally
              
              
    
        {
    
            
              
                this
              
              .sqlConnection1.Close();
    
        }
    
    }
            

Retrieving Image

Retrieving images from the database is the exact reverse process of saving images to the database.

  1. First create command text to retrieve record.
              SqlCommand cmdSelect = 
              
                new
              
               SqlCommand(
              
                "
              
              
                select Picture"
              
               + 
    
                           
              
                "
              
              
                 from tblImgData where ID=@ID"
              
              , 
    
                           
              
                this
              
              .sqlConnection1);
            
  2. Create parameter for the query.
              cmdSelect.Parameters.Add(
              
                "
              
              
                @ID"
              
              ,SqlDbType.Int,
              
                4
              
              );
            
  3. Provide value to the parameter.
              cmdSelect.Parameters[
              
                "
              
              
                @ID"
              
              ].Value=this.editID.Text;
            
  4. Open database connection and execute “ ExecuteScalar ” because we want only “ IMAGE ” column data back.
              
                byte
              
              [] barrImg=(
              
                byte
              
              [])cmdSelect.ExecuteScalar();
            

    As the execute scalar returns data of “ Object ” data type, we cast it to  byte  array.

  5. Save this data to a temporary file.
              
                string
              
               strfn=Convert.ToString(DateTime.Now.ToFileTime());
    
    FileStream fs=new FileStream(strfn,FileMode.CreateNew,FileAccess.Write);
    
    fs.Write(barrImg,
              
                0
              
              ,barrImg.Length);
    
    fs.Flush();
    
    fs.Close();
            
  6. And display the image anywhere you want to display.
              pictureBox1.Image=Image.FromFile(strfn);
            

Complete Image Retrieving Code

      
        private
      
      
        void
      
       btnLoad_Click(
      
        object
      
       sender, System.EventArgs e)

{

    
      
        try
      
      

    {

        SqlCommand cmdSelect=new SqlCommand(
      
        "
      
      
        select Picture"
      
       + 

              
      
        "
      
      
         from tblImgData where ID=@ID"
      
      ,
      
        this
      
      .sqlConnection1);

        cmdSelect.Parameters.Add(
      
        "
      
      
        @ID"
      
      ,SqlDbType.Int,
      
        4
      
      );

        cmdSelect.Parameters[
      
        "
      
      
        @ID"
      
      ].Value=this.editID.Text;



        
      
        this
      
      .sqlConnection1.Open();

        
      
        byte
      
      [] barrImg=(
      
        byte
      
      [])cmdSelect.ExecuteScalar();

        
      
        string
      
       strfn=Convert.ToString(DateTime.Now.ToFileTime());

        FileStream fs=new FileStream(strfn, 

                          FileMode.CreateNew, FileAccess.Write);

        fs.Write(barrImg,
      
        0
      
      ,barrImg.Length);

        fs.Flush();

        fs.Close();

        pictureBox1.Image=Image.FromFile(strfn);

    }

    
      
        catch
      
      (Exception ex)

    {

        MessageBox.Show(ex.Message);

    }

    
      
        finally
      
      

    {

        
      
        this
      
      .sqlConnection1.Close();

    }

}
    

Bibliography

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found  here

Storing and Retrieving Images from SQL Server using Microsoft .NET


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论