色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

net在sql server中的圖片存取技術(例子在管理里inoutimg)

瀏覽:143日期:2023-11-03 13:25:06
本文總結如何在.Net WinForm和.Net WebForm(asp.net)中將圖片存入SQL Server中并讀取顯示的方法 。1.使用asp.net將圖片上傳并存入SQL Server中,然后從SQL Server中讀取并顯示出來:1)上傳并存入SQL Server 數據庫結構 create table test { id identity(1,1), FImage image } 相關的存儲過程 Create proc UpdateImage ( @UpdateImage Image ) As Insert Into test(FImage) values(@UpdateImage) GO 在UpPhoto.aspx文件中添加如下: <input name='UpPhoto' runat='server' type='file'> <asp:Button name='btnAdd' runat='server' Text='上傳'></asp:Button> 然后在后置代碼文件UpPhoto.aspx.cs添加btnAdd按鈕的單擊事件處理代碼: private void btnAdd_Click(object sender, System.EventArgs e) { //獲得圖象并把圖象轉換為byte[] HttpPostedFile upPhoto=UpPhoto.PostedFile; int upPhotoLength=upPhoto.ContentLength; byte[] PhotoArray=new Byte[upPhotoLength]; Stream PhotoStream=upPhoto.InputStream; PhotoStream.Read(PhotoArray,0,upPhotoLength); //連接數據庫 SqlConnection conn=new SqlConnection(); conn.ConnectionString='Data Source=localhost;Database=test;User Id=sa;Pwd=sa'; SqlCommand cmd=new SqlCommand('UpdateImage',conn); cmd.CommandType=CommandType.StoredProcedure; cmd.Parameters.Add('@UpdateImage',SqlDbType.Image); cmd.Parameters['@UpdateImage'].Value=PhotoArray; //如果你希望不使用存儲過程來添加圖片把上面四句代碼改為: //string strSql='Insert into test(FImage) values(@FImage)'; //SqlCommand cmd=new SqlCommand(strSql,conn); //cmd.Parameters.Add('@FImage',SqlDbType.Image); //cmd.Parameters['@FImage'].Value=PhotoArray; conn.Open(); cmd.ExecuteNonQuery(); conn.Close(); } 2)從SQL Server中讀取并顯示出來 在需要顯示圖片的地方添加如下代碼: <asp:image runat='server' ImageUrl='ShowPhoto.aspx'></asp:image> ShowPhoto.aspx主體代碼: private void Page_Load(object sender, System.EventArgs e) { if(!Page.IsPostBack) { SqlConnection conn=new SqlConnection() conn.ConnectionString='Data Source=localhost;Database=test;User Id=sa;Pwd=sa'; string strSql='select * from test where id=2';//這里假設獲取id為2的圖片 SqlCommand cmd=new SqlCommand(strSql,conn); conn.Open();SqlDataReader reader=cmd.ExecuteReader();reader.Read(); Response.ContentType='application/octet-stream'; Response.BinaryWrite((Byte[])reader['FImage']); Response.End(); reader.Close(); } } 2.在WinForm中將圖片存入SQL Server,并從SQL Server中讀取并顯示在picturebox中 1),存入SQL Server 數據庫結構和使用的存儲過過程,同上面的一樣 首先,在窗體中加一個OpenFileDialog控件,命名為ofdSelectPic ;然后,在窗體上添加一個打開文件按鈕,添加如下單擊事件代碼: Stream ms; byte[] picbyte; //ofdSelectPic.ShowDialog(); if (ofdSelectPic.ShowDialog()==DialogResult.OK) { if ((ms=ofdSelectPic.OpenFile())!=null) { //MessageBox.Show('ok'); picbyte=new byte[ms.Length]; ms.Position=0; ms.Read(picbyte,0,Convert.ToInt32(ms.Length)); //MessageBox.Show('讀取完畢!'); //連接數據庫 SqlConnection conn=new SqlConnection(); conn.ConnectionString='Data Source=localhost;Database=test;User Id=sa;Pwd=sa'; SqlCommand cmd=new SqlCommand('UpdateImage',conn); cmd.CommandType=CommandType.StoredProcedure; cmd.Parameters.Add('@UpdateImage',SqlDbType.Image); cmd.Parameters['@UpdateImage'].Value=picbyte; conn.Open(); cmd.ExecuteNonQuery(); conn.Close(); ms.Close(); } } 2)讀取并顯示在picturebox中 首先,添加一個picturebox,名為ptbShow 然后,添加一個按鈕,添加如下響應事件: SqlConnection conn=new SqlConnection(); conn.ConnectionString='Data Source=localhost;Database=test;User Id=sa;Pwd=sa'; string strSql='select FImage from test where id=1'; SqlCommand cmd=new SqlCommand(strSql,conn); conn.Open(); SqlDataReader reader=cmd.ExecuteReader(); reader.Read(); MemoryStream ms=new MemoryStream((byte[])reader['FImage']); Image image=Image.FromStream(ms,true); reader.Close(); conn.Close(); ptbShow.Image=image;
標簽: Sql Server 數據庫
主站蜘蛛池模板: 国产免费爱在线观看视频 | 男女上下爽无遮挡午夜免费视频 | 欧美一区二区三区不卡 | 美女一级片视频 | 久久精视频| a大片久久爱一级 | 国产一区二区在线免费观看 | 国产91精品露脸国语对白 | 9191精品国产费久久 | 成年人网站黄 | 国产又色又爽黄的网站免费 | 日韩美女专区中文字幕 | 色综合久久88色综合天天 | 亚洲第一免费播放区 | 国产成人综合一区精品 | 一区二区视屏 | 欧美α一级毛片 | 一级a毛片 | 欧美6699在线视频免费 | 成 人色 网 站 欧美大片在线观看 | 日本乱子伦xxxx | 国内成人精品亚洲日本语音 | 91香蕉视频网| 欧美成人性色xxxx视频 | 久久精品国产精品青草不卡 | 国产精品自拍在线观看 | 国产美女操 | 婷婷国产成人久久精品激情 | a性片| 欧美成年| 国产欧美视频一区二区三区 | 成年人免费小视频 | 草草视频免费观看 | 欧美日韩一区二区综合 | 另类专区欧美 | 直接在线观看的三级网址 | 男人好大好硬好爽免费视频 | 加勒比毛片 | 在线播放亚洲精品 | 日本一级高清片免费 | 青草福利在线 |