亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Storing and Retrieving Images from SQL Serve

系統 2670 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:

    ?Collapse ?|? Copy Code
              
                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.
      ?Collapse ?|? Copy Code
                    
                      this
                    
                    .openFileDialog1.ShowDialog(
                    
                      this
                    
                    );
      
      
                    
                      string
                    
                     strFn=this.openFileDialog1.FileName;
                  
    2. By using? FileInfo ?class, I retrieved the file size:
      ?Collapse ?|? Copy Code
                    FileInfo fiImage=new FileInfo(strFn);
                  
    3. Declare an array of that size.
      ?Collapse ?|? Copy Code
                    
                      this
                    
                    .m_lImageFileLength=fiImage.Length;
      
      m_barrImg=new 
                    
                      byte
                    
                    [Convert.ToInt32(
                    
                      this
                    
                    .m_lImageFileLength)];
                  
    4. By using? FileStream ?object, I filled the byte array.
      ?Collapse ?|? Copy Code
                    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

    ?Collapse ?|? Copy 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.
      ?Collapse ?|? Copy Code
                    
                      this
                    
                    .sqlCommand1.CommandText= 
      
        
                    
                      "
                    
                    
                      INSERT INTO tblImgData(ID,Name,Picture)"
                    
                     + 
      
        
                    
                      "
                    
                    
                       values(@ID,@Name,@Picture)"
                    
                    ;
                  
    2. Create parameters.
      ?Collapse ?|? Copy Code
                    
                      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.
      ?Collapse ?|? Copy Code
                    
                      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.
      ?Collapse ?|? Copy Code
                    
                      int
                    
                     iresult=this.sqlCommand1.ExecuteNonQuery();
                  

    Complete Save Image Code

    ?Collapse ?|? Copy 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.
    ?Collapse ?|? Copy Code
              SqlCommand cmdSelect = 
              
                new
              
               SqlCommand(
              
                "
              
              
                select Picture"
              
               + 
    
                           
              
                "
              
              
                 from tblImgData where ID=@ID"
              
              , 
    
                           
              
                this
              
              .sqlConnection1);
            
  2. Create parameter for the query.
    ?Collapse ?|? Copy Code
              cmdSelect.Parameters.Add(
              
                "
              
              
                @ID"
              
              ,SqlDbType.Int,
              
                4
              
              );
            
  3. Provide value to the parameter.
    ?Collapse ?|? Copy Code
              cmdSelect.Parameters[
              
                "
              
              
                @ID"
              
              ].Value=this.editID.Text;
            
  4. Open database connection and execute “ ExecuteScalar ” because we want only “ IMAGE ” column data back.
    ?Collapse ?|? Copy Code
              
                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.
    ?Collapse ?|? Copy Code
              
                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.
    ?Collapse ?|? Copy Code
              pictureBox1.Image=Image.FromFile(strfn);
            

Complete Image Retrieving Code

?Collapse ?|? Copy 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條評論
主站蜘蛛池模板: 九九热视频精品 | 尤物久久99热国产综合 | 免费视频网站一级人爱视频 | 精品国精品国产自在久国产不卡 | 免费看美女隐私的网站 | 热久久这里只有精品 | 黄色成人一级片 | 综合网色| 美女黄色免费在线观看 | 日本一本在线观看 | 成人国产精品999视频 | 国产成人看片免费视频观看 | 九九精品成人免费国产片 | 国产麻豆高清视频在线第一页 | 香蕉成人在线视频 | 91精品啪国产在线观看免费牛牛 | 国国产自国偷自产第38页 | 美女被cao的视频免费看 | 99爱精品视频 | 操操干 | 亚洲精品美女国产一区 | 亚洲国产人成中文幕一级二级 | 日韩经典中文字幕 | 成人高清视频在线观看大全 | 欧美国产大片 | 亚洲天堂一区二区三区 | 久久精品国产99久久6动漫欧 | 日韩在线一区二区 | 免费毛片播放 | 四虎影视在线看免费观看 | 成人午夜性视频欧美成人 | 天天躁天天碰天天看 | 嘿咻嘿咻免费区在线观看吃奶 | 综合成人在线 | 欧美激情在线免费观看 | 亚洲欧美天堂网 | 日本一级毛片视频在线看 | 日韩欧美高清在线 | 成人yyyy| 欧美日韩亚洲m码色帝国 | 日韩女人毛片在线播放 |