和存储图片相比,读取图片就要简单多了。输出一副图片我们要做的就是使用Response对象的BinaryWrite方法。 
  同时设置图片的格式。在这篇文章中,我们将讨论如何从SqlServer中检索图片。并将学习以下几个方面的知识。 
  ·如何设置图片的格式? 
  ·如何使用BinaryWrite方法。 
  我们已经在Person表中存储了数据,那么我们就写些代码来从表中读取数据。 
  下面的代码检索了所有的值从Person表中。 
  从sqlserver中读取图片的代码。 
Public Sub Page_Load(sender As Object, e As EventArgs) 
Dim myConnection As New SqlConnection(ConfigurationSettings.AppSettings("ConnectionString")) 
Dim myCommand As New SqlCommand("Select * from Person", myConnection) 
Try 
myConnection.Open() 
Dim myDataReader as SqlDataReader 
myDataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection) 
Do While (myDataReader.Read()) 
Response.ContentType = myDataReader.Item("PersonImageType") 
Response.BinaryWrite(myDataReader.Item("PersonImage")) 
Loop 
myConnection.Close() 
Response.Write("Person info successfully retrieved!") 
Catch SQLexc As SqlException 
Response.Write("Read Failed : " & SQLexc.ToString()) 
End Try 
End Sub 
  看看他是怎么工作的? 
  上面的例子很简单。我们所作的就是执行一个sql语句,再循环读取所有的记录(looping through all the records). 
 在显示图片之前,我们先设置了图片的contentType,然后我们使用BinaryWrite方法把图片输出到浏览器。 
源代码: 
/// retriving.aspx 
<%@ Page Language="vb" %> 
<%@ Import Namespace="System.Data" %> 
<%@ Import Namespace="System.Data.SqlClient" %> 
<HTML> 
<HEAD> 
<title>Retrieving Image from the Sql Server</title> 
<script runat=server> 
Public Sub Page_Load(sender As Object, e As EventArgs) 
' Create Instance of Connection and Command Object 
Dim myConnection As New SqlConnection(ConfigurationSettings.AppSettings("ConnectionString")) 
Dim myCommand As New SqlCommand("Select * from Person", myConnection) 
Try 
myConnection.Open() 
Dim myDataReader as SqlDataReader 
myDataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection) 
Do While (myDataReader.Read()) 
Response.ContentType = myDataReader.Item("PersonImageType") 
Response.BinaryWrite(myDataReader.Item("PersonImage")) 
Loop 
myConnection.Close() 
Response.Write("Person info successfully retrieved!") 
Catch SQLexc As SqlException 
Response.Write("Read Failed : " & SQLexc.ToString()) 
End Try 
End Sub 
</script> 
</HEAD> 
<body style="font: 10pt verdana"> 
</body> 
</HTML> 

博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3