<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        把圖片保存到數據庫中和從數據庫中讀取圖片

        來源:懂視網 責編:小采 時間:2020-11-09 16:03:53
        文檔

        把圖片保存到數據庫中和從數據庫中讀取圖片

        把圖片保存到數據庫中和從數據庫中讀取圖片:最近做到一個小項目,其中關系到圖片的一些操作。比如:將圖片保存到數據庫中、從數據庫中讀取圖片、顯示圖片、打印圖片等。此處對這些在項目中遇到的一些瑣碎知識加以總結,以便日后查找。 1、將圖片作為其中的一個參數保存到數據庫中 在項目中,一般是將圖
        推薦度:
        導讀把圖片保存到數據庫中和從數據庫中讀取圖片:最近做到一個小項目,其中關系到圖片的一些操作。比如:將圖片保存到數據庫中、從數據庫中讀取圖片、顯示圖片、打印圖片等。此處對這些在項目中遇到的一些瑣碎知識加以總結,以便日后查找。 1、將圖片作為其中的一個參數保存到數據庫中 在項目中,一般是將圖

        最近做到一個小項目,其中關系到圖片的一些操作。比如:將圖片保存到數據庫中、從數據庫中讀取圖片、顯示圖片、打印圖片等。此處對這些在項目中遇到的一些瑣碎知識加以總結,以便日后查找。 1、將圖片作為其中的一個參數保存到數據庫中 在項目中,一般是將圖

          最近做到一個小項目,其中關系到圖片的一些操作。比如:將圖片保存到數據庫中、從數據庫中讀取圖片、顯示圖片、打印圖片等。此處對這些在項目中遇到的一些瑣碎知識加以總結,以便日后查找。

          1、將圖片作為其中的一個參數保存到數據庫中

          在項目中,一般是將圖片轉換成二進制流格式,然后保存到數據庫中。同時數據庫表中存儲圖片的格式一般為image。此次項目,是將圖片作為一個參數,和其他幾個參數一起保存到數據庫中,和在網上搜索到的圖片保存不太一樣,此處稍作修改,但都是檢測過的。

          存儲步驟:

          1、搜索到圖片的路徑

          2、讀取圖片并將圖片轉換成二進制流格式

          3、sql語句保存到數據庫中。

          貼代碼: 

        private void btnWrite_Click(object sender, EventArgs e)
         {
         OpenFileDialog ofd = new OpenFileDialog();
         ofd.Filter = "*jpg|*.JPG|*.GIF|*.GIF|*.BMP|*.BMP";
        
         if (ofd.ShowDialog() == DialogResult.OK)
         {
         string filePath = ofd.FileName;//圖片路徑
         FileStream fs = new FileStream(filePath, FileMode.Open);
         byte[] imageBytes = new byte[fs.Length];
         BinaryReader br = new BinaryReader(fs);
         imageBytes = br.ReadBytes(Convert.ToInt32(fs.Length));//圖片轉換成二進制流
        
         string strSql = string.Format("insert into [SBS].[dbo].[Model] ([M_QRCode],[M_Skills] ) values (@image,'2')");
         int count = Write(strSql,imageBytes );
        
         if (count > 0)
         {
         MessageBox.Show("success");
         }
         else
         {
         MessageBox.Show("failed");
         }
         }
         }

          數據庫連接和保存圖片語句:

        private int Write(string strSql,byte[] imageBytes)
         {
         string connStr = "Data Source=192.168.4.132;initial Catalog=SBS;User ID=sa;Password=sa;";
        
         using (SqlConnection conn = new SqlConnection(connStr))
         {
         using (SqlCommand cmd = new SqlCommand(strSql, conn))
         {
         try
         {
         conn.Open();
         SqlParameter sqlParameter = new SqlParameter("@image", SqlDbType.Image);
         sqlParameter.Value = imageBytes;
         cmd.Parameters.Add(sqlParameter);
         int rows = cmd.ExecuteNonQuery();
         return rows;
         }
         catch (Exception e)
         {
         throw;
         }
         }
         }
         }

        View Code

          2、從數據庫總讀取圖片

          從數據庫中讀取圖片字段,并轉換成內存流生成bitmap。

          貼代碼: 

        private void btnRead_Click(object sender, EventArgs e)
         {
         string strSql = string.Format("select M_QRCode from [SBS].[dbo].[Model] where M_id = 7");//圖片保存的字段是M_QRCode
         Read(strSql);
         }
        
         private void Read(string strSql)
         {
         string connStr = "Data Source=192.168.4.132;initial Catalog=SBS;User ID=sa;Password=sa;";
        
         using (SqlConnection conn = new SqlConnection(connStr))
         {
         using (SqlCommand cmd = new SqlCommand(strSql, conn))
         {
         conn.Open();
         SqlDataReader sqlDr = cmd.ExecuteReader();
         sqlDr.Read();
         byte[] images = (byte[])sqlDr["M_QRCode"];
         MemoryStream ms = new MemoryStream(images);
         Bitmap bmp = new Bitmap(ms);
         pictureBox1.Image = bmp;
         }
         }
         }

          3、根據圖片路徑顯示圖片

          這個比較簡單,直接貼出代碼 

        private void btnLoad_Click(object sender, EventArgs e)
         {
         OpenFileDialog ofd = new OpenFileDialog();
         ofd.Filter = "*jpg|*.JPG|*.GIF|*.GIF|*.BMP|*.BMP";
         if (ofd.ShowDialog() == DialogResult.OK)
         {
         pictureBox1.Image = Image.FromFile(ofd.FileName);
         }
         }

          4、打印圖片

          打印圖片是在將圖片顯示在pictureBox的基礎上進行的。

          步驟:

          1、將printDocument控件拖到界面,添加打印代碼

          2、設置PrintDocument控件的Print_PrintPage事件

        private void btnPrint_Click(object sender, EventArgs e)
         {
         PrintDialog printDialog = new PrintDialog();
         printDialog.Document = this.printDocument1;
         if (printDialog.ShowDialog() == DialogResult.OK)
         {
         try
         {
         printDocument1.Print();
         }
         catch (Exception ex)
         {
         printDocument1.PrintController.OnEndPrint(printDocument1, new System.Drawing.Printing.PrintEventArgs());
         }
         }
         }
        
         private void printDocument1_PrintPage(object sender, System.Drawing.Printing.PrintPageEventArgs e)
         {
         e.Graphics.DrawImage(pictureBox1.Image, 30, 30);
         }

          

          附帶著將圖片轉換成二進制和將二進制轉換成圖片專門寫出來,以便于查看。 

         public byte[] ConvertBinary(string filePath)
         {
         FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read);//以文件流形式讀取圖片
         BinaryReader br = new BinaryReader(fs);//轉換成二進制流
         byte[] imageBytes = br.ReadBytes((int)fs.Length);//保存到字節數組中
        
         return imageBytes;
         }
        
         public void ShowImage(byte[] imageBytes)
         {
         MemoryStream ms = new MemoryStream(imageBytes);
         pictureBox1.Image = Image.FromStream(ms);
         }

          在pictureBox中顯示圖片的三種方式: 

        public void Method()
         {
         MemoryStream ms;
         pictureBox1.Image = Image.FromStream(ms);
        
         Bitmap bitmap;
         pictureBox1.Image = bitmap;
        
         string filePath;
         pictureBox1.Image = Image.FromFile(filePath);
         }

          winform中控件combobox控件使用: 

        public void BindCombobox()
         {
         DataTable dt = new DataTable();
         dt.Columns.Add(new DataColumn("id", typeof(int)));
         dt.Columns.Add(new DataColumn("value", typeof(string)));
        
         for (int i = 0; i < 3; i++)
         {
         DataRow dr = dt.NewRow();
         dr["id"] = i;
         dr["value"] = 10 + i;
         dt.Rows.Add(dr);
         }
        
         this.comboBox1.DataSource = dt;
         this.comboBox1.DisplayMember = "value";
         this.comboBox1.ValueMember = "id"; 
         }
        
         public void ShowValue()
         {
         this.textBox1.Text = this.comboBox1.Text;
         this.textBox2.Text = this.comboBox1.SelectedValue.ToString();
         }

          

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        把圖片保存到數據庫中和從數據庫中讀取圖片

        把圖片保存到數據庫中和從數據庫中讀取圖片:最近做到一個小項目,其中關系到圖片的一些操作。比如:將圖片保存到數據庫中、從數據庫中讀取圖片、顯示圖片、打印圖片等。此處對這些在項目中遇到的一些瑣碎知識加以總結,以便日后查找。 1、將圖片作為其中的一個參數保存到數據庫中 在項目中,一般是將圖
        推薦度:
        標簽: 保存 圖片 一個
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲欧美日韩综合久久久久 | 久久九九免费高清视频| 日本免费一区二区三区最新vr| 亚洲偷自精品三十六区| 永久免费的网站在线观看| 亚洲入口无毒网址你懂的| 野花高清在线观看免费完整版中文| 亚洲av无码电影网| 免费A级毛片无码免费视| 亚洲性无码一区二区三区| 国产在线观看免费不卡| 美女被暴羞羞免费视频| 精品亚洲视频在线观看| 男人的天堂网免费网站| 亚洲精品综合久久中文字幕 | 亚洲国产主播精品极品网红| 亚洲黄片手机免费观看| 久久精品国产69国产精品亚洲| 久久久高清日本道免费观看| 777亚洲精品乱码久久久久久| 亚洲天堂免费在线| 亚洲乱妇熟女爽到高潮的片| 亚洲高清无码综合性爱视频| 无码午夜成人1000部免费视频| 亚洲人成影院在线高清| 全部免费a级毛片| 久久er国产精品免费观看2| 亚洲午夜精品一区二区公牛电影院 | 亚洲国产精品免费在线观看| 国产精品美女午夜爽爽爽免费| 黄网站色视频免费观看45分钟| 亚洲av综合av一区| 无码日韩人妻av一区免费| 免费看内射乌克兰女| 亚洲国产精品一区二区久久| 色视频色露露永久免费观看| 中文字幕a∨在线乱码免费看 | 亚洲bt加勒比一区二区| 黄网址在线永久免费观看| 成在人线av无码免费高潮水| 亚洲国产综合人成综合网站00|