使用.NET向SQL Server数据库存取图片
创始人
2024-04-28 17:21:04
0

使用.NET向SQL Server数据库存取图片

使用.Net技术,我们可以很方便的将图片存入SQL Server数据库中并方便的读取显示出来,详细的实现方法我们一步一步将会了解到。先说如何将图片存储到sql server数据库中:

.NET向SQL Server数据库存取图片技巧:存入图片

使用asp.net将图片上传并存入SQL Server中,然后从SQL Server中读取并显示出来:

1)上传并存入SQL Server

数据库结构

  1. create table test   
  2. {   
  3. id identity(1,1),   
  4. FImage image   
  5. }   

相关的存储过程

  1. Create proc UpdateImage   
  2. (   
  3. @UpdateImage Image   
  4. )   
  5. As   
  6. Insert Into test(FImage) values(@UpdateImage)   
  7. GO   

在UpPhoto.aspx文件中添加如下: 

  1. < input id="UpPhoto" name="UpPhoto" runat="server" type="file">   
  2. < asp:Button id="btnAdd" name="btnAdd" runat="server" Text="上传">< /asp:Button> 

然后在后置代码文件UpPhoto.aspx.cs添加btnAdd按钮的单击事件处理代码:

  1. private void btnAdd_Click(object sender, System.EventArgs e)   
  2. {   
  3. //获得图象并把图象转换为byte[]   
  4. HttpPostedFile upPhoto=UpPhoto.PostedFile;   
  5. int upPhotoLength=upPhoto.ContentLength;   
  6. byte[] PhotoArray=new Byte[upPhotoLength];   
  7. Stream PhotoStream=upPhoto.InputStream;   
  8. PhotoStream.Read(PhotoArray,0,upPhotoLength);   
  9. //连接数据库   
  10. SqlConnection conn=new SqlConnection();   
  11. conn.ConnectionString="Data Source=localhost;Database=test;User Id=sa;Pwd=sa";   
  12. SqlCommand cmd=new SqlCommand("UpdateImage",conn);   
  13. cmd.CommandType=CommandType.StoredProcedure;   
  14. cmd.Parameters.Add("@UpdateImage",SqlDbType.Image);   
  15. cmd.Parameters["@UpdateImage"].Value=PhotoArray;   
  16. //如果你希望不使用存储过程来添加图片把上面四句代码改为:   
  17. //string strSql="Insert into test(FImage) values(@FImage)";   
  18. //SqlCommand cmd=new SqlCommand(strSql,conn);   
  19. //cmd.Parameters.Add("@FImage",SqlDbType.Image);   
  20. //cmd.Parameters["@FImage"].Value=PhotoArray;   
  21. conn.Open();   
  22. cmd.ExecuteNonQuery();   
  23. conn.Close();   
  24. }  

.NET向SQL Server数据库存取图片技巧:从SQL Server中读取并显示出来

在需要显示图片的地方添加如下代码:

  1. < asp:image id="imgPhoto" runat="server" ImageUrl="ShowPhoto.aspx">< /asp:image>  

ShowPhoto.aspx主体代码:

  1. private void Page_Load(object sender, System.EventArgs e)   
  2. {   
  3. if(!Page.IsPostBack)   
  4. {   
  5. SqlConnection conn=new SqlConnection()   
  6. conn.ConnectionString="Data Source=localhost;Database=test;User Id=sa;Pwd=sa";   
  7. string strSql="select * from test where id=2";//这里假设获取id为2的图片   
  8. SqlCommand cmd=new SqlCommand(strSql,conn);   
  9. conn.Open();  
  10. SqlDataReader reader=cmd.ExecuteReader();  
  11. reader.Read();   
  12. Response.ContentType="application/octet-stream";   
  13. Response.BinaryWrite((Byte[])reader["FImage"]);   
  14. Response.End();   
  15. reader.Close();   
  16. }   

以上就介绍了.NET向SQL Server数据库存取图片的实现方法。

【编辑推荐】

  1. .NET二进制图片存储与读取的常见方法
  2. ASP.NET和SQL Server数据库图片存储的实现
  3. ASP.NET数据库图片存储到Sql2000中
  4. ASP.NET数据库图片上传与读取的实现
  5. ASP.NET(VB)应用之图片增加水印文字浅析

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...