<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
        主站蜘蛛池模板: 97无码免费人妻超级碰碰夜夜| 草久免费在线观看网站| 91香蕉国产线在线观看免费| 亚洲一区二区三区自拍公司| 久久久久久毛片免费看 | 国产电影午夜成年免费视频| 亚洲Av综合色区无码专区桃色| a视频在线免费观看| 国产v亚洲v天堂无码网站| 久久久久久免费一区二区三区| 国产成人亚洲综合色影视| 久久免费视频99| 亚洲国产精品张柏芝在线观看 | 亚洲国产综合AV在线观看| 成人一a毛片免费视频| 在线播放亚洲精品| 亚洲一区二区视频在线观看 | 免费看又黄又爽又猛的视频软件| 亚洲成人一区二区| 91视频精品全国免费观看| 亚洲天堂中文资源| 久久精品网站免费观看 | 免费毛片在线看不用播放器 | 亚洲妇女熟BBW| 国产一级做a爱免费视频| jizz在线免费观看| 久久亚洲私人国产精品| 久久电影网午夜鲁丝片免费| 亚洲AⅤ男人的天堂在线观看| 精品国产香蕉伊思人在线在线亚洲一区二区| 中文字幕永久免费视频| 亚洲精品乱码久久久久久下载 | aⅴ在线免费观看| 亚洲精品无码久久久久牙蜜区| 亚洲无码日韩精品第一页| 日韩人妻一区二区三区免费| 亚洲人成色777777老人头| 亚洲日韩av无码| 最新中文字幕免费视频| 巨胸喷奶水www永久免费| 国产精品亚洲四区在线观看|