介绍如何将图片存入数据库
如何使用MySQL进行图像存储与处理

如何使用MySQL进行图像存储与处理随着信息技术的快速发展,图像处理与存储成为了计算机领域的一个重要课题。
MySQL作为一个开源的关系型数据库管理系统,不仅具备高可扩展性和可靠性,还提供了强大的数据处理和存储功能。
本文将探讨如何使用MySQL进行图像存储与处理,并介绍一些相关的技术和工具。
一、MySQL中存储图像的方法在MySQL中存储图像的方法有很多种,根据实际需求选择最合适的方法可以提高效率和可维护性。
1. 使用BLOB类型存储图像数据BLOB(Binary Large Object)是MySQL中一种特殊的数据类型,用于存储大型二进制数据。
可以将图像以二进制的形式存储在数据库中,并使用BLOB类型将其存储起来。
BLOB类型可以存储任意大小的二进制数据,适用于图像、音频、视频等多媒体数据的存储。
创建一个BLOB类型的列,并将图像数据以二进制形式插入到数据库中。
2. 使用BASE64编码存储图像数据在MySQL中,还可以使用BASE64编码将图像数据进行存储。
BASE64是一种将二进制数据编码为ASCII字符的方法。
可以将图像数据转换为BASE64编码的字符串,并将其存储在数据库中。
在需要使用图像数据时,再将BASE64编码的字符串解码为二进制数据。
使用BASE64编码存储图像数据可以提高数据的可读性和可传输性,但会增加数据的存储空间。
二、MySQL中图像的处理与操作除了存储图像数据,MySQL还提供了一些函数和技术,可以对存储在数据库中的图像数据进行处理和操作。
1. 使用MySQL提供的图像处理函数MySQL提供了一些内置的图像处理函数,用于对存储在数据库中的图像数据进行处理。
例如,可以使用函数CONVERT将图像数据从一种格式转换为另一种格式。
可以使用函数RESIZE调整图像的尺寸。
还可以使用函数ROTATE对图像进行旋转。
使用MySQL提供的图像处理函数可以方便地对图像数据进行处理,而不需要将数据导出到外部工具进行处理。
详解图片上传到数据库

详解图片上传到数据库数据库中的储存内容不是单单的数据,内容也是丰富多彩的,如今数据库可以实现将图片上传到数据库,下文中就为大家详细介绍将图片上传到数据库的知识。
下面我来汇总一下如何将图片保存到SqlServer、Oracle、Access数据库中,下文内容供大家参考学习,希望对大家能够有所帮助。
首先,我们要明白图片是以二进制的形式保存在数据库中的,那么把图片保存到数据库中的步骤大体上有这几步1.将图片转换为二进制数组(byte[]);2.把转换后的二进制数组(byte[])作为参数传递给要执行的Command;3.执行Command;首先,如何把图片转换成byte[],如果你使用的是2.0,那么你可以使用FileUpLoad控件来实现byte[] fileData = this.FileUpload1.FileBytes;如果你用的是1.1或者你在创建WinForm那么你可以使用下面的方法来把图片转换为byte[]1public byte[] getBytes(string filePath)2{3System.IO.FileStream fs = new System.IO.FileStream(filePath, System.IO.FileMode.Open);4byte[] imgData = new byte[fs.Length];5fs.Read(imgData, 0, (int)fs.Length);6return imgData;7}8接下来我们要做的就是要把已经得到的byte[]作为参数传递给Command对象1.SqlServer数据库。
SqlServer有Image字段类型,最大可以存储2G的数据。
byte[] fileData = this.FileUpload1.FileBytes;9string sql = "insert into t_img(img) values (@img)";10string strconn = System.Configuration.ConfigurationManager.ConnectionStrings["fengd ongDB"].ToString();11SqlConnection sqlConn = new SqlConnection(strconn);12SqlCommand sqlComm = new SqlCommand(sql, sqlConn);13sqlComm.Parameters.Add("@img", SqlDbType.Image);//添加参数14sqlComm.Parameters["@img"].Value = fileData;//为参数赋值1516sqlConn.Open();17sqlComm.ExecuteNonQuery();18sqlConn.Close();192.Oracle数据库。
存储过程_将图片存入数据库

一、写一个存储过程,将图片存入数据库中基本情况介绍:数据库版本:oracle 11g数据库用户:scott数据库密码:tigerJDK:1.6要导入的图片:D:\picture\1.jpg--创建存储图片的表CREATE TABLE IMAGE_LOB (T_ID V ARCHAR2 (5) NOT NULL,T_IMAGE BLOB NOT NULL);--创建存储图片的目录CREATE OR REPLACE DIRECTORY IMAGES AS 'D:\picture';存储过程如下:CREATE OR REPLACE PROCEDURE IMG_INSERT (TID V ARCHAR2,FILENAME V ARCHAR2) ASF_LOB BFILE;--文件类型B_LOB BLOB;BEGINiNSERT INTO IMAGE_LOB (T_ID, T_IMAGE)V ALUES (TID,EMPTY_BLOB ()) RETURN T_IMAGE INTO B_LOB;--插入空的blobF_LOB:= BFILENAME ('IMAGES', FILENAME);--获取指定目录下的文件DBMS_LOB.FILEOPEN(F_LOB, DBMS_LOB.FILE_READONL Y);--以只读的方式打开文件DBMS_LOB.LOADFROMFILE (B_LOB, F_LOB,DBMS_LOB.GETLENGTH (F_LOB));--传递对象DBMS_LOB.FILECLOSE (F_LOB);--关闭原始文件COMMIT;END;--将该图片存入表call IMG_INSERT('1','1.gif'); 验证一下是否已存入:二、从数据库读取图片并显示在页面上项目名称为ShowPhoto启动Tomcat,在浏览器输入:http://localhost:8080/ShowPhoto/,显示如下:。
图片保存到mysql数据库

在我们设计和制作网站的过程中,有时把图片保存到数据库中要比存成文件的形式更加方便。
PHP和MySQL这对黄金组合可以很容易的实现上述功能。
在本文中,我们将会向读者介绍如何把图片保存到MySQL数据库中以及如何将数据库中的图片显示出来。
设置数据库我们通常在数据库中所使用的文本或整数类型的字段和需要用来保存图片的字段的不同之处就在于两者所需要保存的数据量不同。
MySQL数据库使用专门的字段来保存大容量的数据,数据类型为BLOB。
MySQL数据库为BLOB做出的定义如下:BLOB数据类型是一种大型的二进制对象,可以保存可变数量的数据。
BLOB具有四种类型,分别是TINYBLOB,BLOB, MEDIUMBLOB 和LONGBLOB,区别在于各自所能够保存的最大数据长度不同。
在介绍了所需要使用的数据类型之后,我们可以使用以下语句创建保存图象的数据表。
CREATE TABLE Images ( PicNum int NOT NULL AUTO_INCREMENT PRIMARY KEY, Image BLOB );编写上传脚本关于如何实现文件的上传,我们在这里就不再介绍了。
现在,我们主要来看一下如何接收上传文件并将其存入到MySQL数据库中。
具体的脚本代码如下,其中我们假定文件上传域的名称为Picture。
<? If($Picture != "none") { $PSize = filesize($Picture); $mysqlPicture = addslashes(fread (fopen($Picture, "r"), $PSize)); mysql_connect($host,$username,$password) or die("Unable to connect to SQL server"); @mysql_select_db($db) or die("Unable to select database"); mysql_query("INSERT INTO Images (Image) VALUES '($mysqlPicture')") or die("Can't Perform Query"); } else { echo"You did not upload any picture"; } ?>这样,我们就可以成功的把图片保存到数据库中。
使用MySQL进行图像存储和检索

使用MySQL进行图像存储和检索近年来,随着互联网的快速发展,图像处理和存储技术成为了研究和应用的热点之一。
在众多的数据库管理系统中,MySQL以其灵活性、高性能和可靠性而受到广泛关注。
本文将探讨如何使用MySQL进行图像存储和检索。
一、介绍图像存储和检索是指将图像文件存储到数据库,并通过各种方式对图像进行搜索和查询的过程。
在传统的图像存储方式中,我们常常将图像文件存储在文件系统中,然后利用文件路径进行检索。
然而,这种方式存在一些问题,比如不便于图像的组织和管理,不方便进行多条件的查询等。
而使用MySQL进行图像存储和检索,可以更好地解决这些问题。
二、图像存储在MySQL中存储图像可以使用BLOB(Binary Large Object)类型。
BLOB类型可以存储二进制数据,包括图像、音频、视频等。
在创建数据表时,可以为图像字段指定BLOB类型。
例如,创建一个名为image_table的数据表,其中包含一个image字段:CREATE TABLE image_table (id INT NOT NULL AUTO_INCREMENT,image BLOB,PRIMARY KEY (id));然后,可以使用INSERT语句将图像文件存储在image字段中。
例如,假设有一个名为image.jpg的图像文件,可以执行以下SQL语句将其存储在image_table 表中:INSERT INTO image_table (image) VALUES (LOAD_FILE('path/to/image.jpg'));需要注意的是,LOAD_FILE函数需要指定图像文件的完整路径。
同时,需要确保MySQL的配置文件中开启了该函数的权限。
三、图像检索在MySQL中进行图像检索可以借助于图像特征提取和相似度计算的技术。
常用的图像特征包括颜色直方图、纹理特征、形状特征等。
可以使用图像处理库,如OpenCV等,对图像进行特征提取,并将提取到的特征存储在MySQL数据库中。
将图片储存在MySQL数据库中的几种方法

将图⽚储存在MySQL数据库中的⼏种⽅法通常对⽤户上传的图⽚需要保存到数据库中。
解决⽅法⼀般有两种:1、将图⽚保存的路径存储到数据库;2、将图⽚以⼆进制数据流的形式直接写⼊数据库字段中。
以下为具体⽅法:⼀、保存图⽚的上传路径到数据库: string uppath="";//⽤于保存图⽚上传路径 //获取上传图⽚的⽂件名 string fileFullname = this.FileUpload1.FileName; //获取图⽚上传的时间,以时间作为图⽚的名字可以防⽌图⽚重名 string dataName = DateTime.Now.ToString("yyyyMMddhhmmss"); //获取图⽚的⽂件名(不含扩展名) string fileName = fileFullname.Substring(stIndexOf("\\") + 1); //获取图⽚扩展名 string type = fileFullname.Substring(stIndexOf(".") + 1); //判断是否为要求的格式 if (type == "bmp" || type == "jpg" || type == "jpeg" || type == "gif" || type == "JPG" || type == "JPEG" || type == "BMP" || type == "GIF") { //将图⽚上传到指定路径的⽂件夹 this.FileUpload1.SaveAs(Server.MapPath("~/upload") + "\\" + dataName + "." + type); //将路径保存到变量,将该变量的值保存到数据库相应字段即可 uppath = "~/upload/" + dataName + "." + type; }⼆、将图⽚以⼆进制数据流直接保存到数据库:引⽤如下命名空间:using System.Drawing; using System.IO; using System.Data.SqlClient; 设计数据库时,表中相应的字段类型为iamge 保存: //图⽚路径 string strPath = this.FileUpload1.PostedFile.FileName.ToString (); //读取图⽚ FileStream fs = new System.IO.FileStream(strPath, FileMode.Open, FileAccess.Read); BinaryReader br = new BinaryReader(fs); byte[] photo = br.ReadBytes((int)fs.Length); br.Close(); fs.Close(); //存⼊ SqlConnection myConn = new SqlConnection("Data Source=.;Initial Catalog=stumanage;User ID=sa;Password=123"); string strComm = " INSERT INTO stuInfo(stuid,stuimage) VALUES(107,@photoBinary )";//操作数据库语句根据需要修改 SqlCommand myComm = new SqlCommand(strComm, myConn); myComm.Parameters.Add("@photoBinary", SqlDbType.Binary, photo.Length); myComm.Parameters["@photoBinary"].Value = photo; myConn.Open(); if (myComm.ExecuteNonQuery() > 0) { bel1.Text = "ok"; } myConn.Close(); 读取: ...连接数据库字符串省略 mycon.Open(); SqlCommand command = new SqlCommand("select stuimage from stuInfo where stuid=107", mycon);//查询语句根据需要修改 byte[] image = (byte[])command.ExecuteScalar (); //指定从数据库读取出来的图⽚的保存路径及名字 string strPath = "~/Upload/zhangsan.JPG"; string strPhotoPath = Server.MapPath(strPath); //按上⾯的路径与名字保存图⽚⽂件 BinaryWriter bw = new BinaryWriter(File.Open(strPhotoPath,FileMode.OpenOrCreate)); bw.Write(image); bw.Close(); //显⽰图⽚ this.Image1.ImageUrl = strPath; //采⽤这两种⽅式可以根据实际需求灵活选择。
如何使用MySQL进行图像和多媒体数据的存储

如何使用MySQL进行图像和多媒体数据的存储MySQL是一种常用的关系型数据库管理系统,广泛应用于各种应用和领域。
它提供了丰富的功能和灵活的存储选项,包括图像和多媒体数据的存储。
本文将探讨如何使用MySQL来有效地存储和管理图像和多媒体数据,以提高应用程序的性能和用户体验。
1. 导入图像和多媒体数据在MySQL中存储图像和多媒体数据的第一步是将这些数据导入到数据库中。
可以通过多种方式实现这一目标,其中一种常用的方法是使用BLOB类型。
BLOB是Binary Large Object的缩写,它允许将二进制数据以字节的形式存储在数据库中。
为了导入图像和多媒体数据,可以使用MySQL提供的LOAD_FILE()函数。
该函数可以将文件中的数据读取为二进制字符串,并将其插入到BLOB列中。
下面是一个示例代码:```INSERT INTO media_data (id, data)VALUES (1, LOAD_FILE('/path/to/image.jpg'));```在上述示例中,media_data是包含BLOB列的表名,id是数据的唯一标识符,data是BLOB列的名称。
通过指定正确的文件路径,可以将图像或多媒体文件插入到数据库中。
2. 使用合适的数据类型和存储格式除了BLOB类型外,MySQL还提供了其他几种数据类型和存储格式,用于存储图像和多媒体数据。
选择正确的数据类型和存储格式可以提高存储效率和访问性能。
一种常见的选择是使用VARCHAR类型存储图像和多媒体数据的URL或文件路径。
通过存储URL或文件路径,可以避免在数据库中存储大型二进制数据。
这种方法适用于将图像和多媒体数据存储在文件系统中,而不是直接存储在数据库中。
另一种选择是使用MEDIUMBLOB或LONGBLOB类型存储二进制数据。
MEDIUMBLOB可以存储最大为16MB的二进制数据,而LONGBLOB可以存储最大为4GB的二进制数据。
图片存入mySql数据库

我在程序代码里贴了向Mysql数据库写入image代码的程序,可是好多人都是Java的初学者,对于这段代码,他们无法将它转换成jsp,所以我在这在写一下用jsp怎样向数据库写入图像文件。
大家先在数据库建这样一张表,我下面的这些代码对任何数据库都通用,只要支持blob类型的只要大家将连接数据库的参数改一下就可以了。
SQL>create table image(id int,content varchar(200),image blob);如果在sqlserver2000的数据库中,可以将blob字段换为image类型,这在SqlServer2000中是新增的。
testimage.html文件内容如下:<HTML><HEAD><TITLE>Image File </TITLE><meta http-equiv="Content-Type" content="text/html; charset=gb2312"></HEAD><FORM METHOD=POST ACTION="testimage.jsp"><INPUT TYPE="text" NAME="content"><BR><INPUT TYPE="file" NAME="image"><BR><INPUT TYPE="submit"></FORM><BODY></BODY></HTML>我们在Form的action里定义了一个动作testimage.jsp,它的内容如下:<%@ page contentType="text/html;charset=gb2312"%><%@ page import="java.sql.*" %><%@ page import="java.util.*"%><%@ page import="java.text.*"%><%@ page import="java.io.*"%><html><body><%Class.forName("org.gjt.mm.mysql.Driver").newInstance();Stringurl="jdbc:mysql://localhost/mysql?user=root&password=&useUnicode=true&characterEncoding= 8859_1";//其中mysql为你数据库的名字,user为你连接数据库的用户,password为你连接数据库用户的密码,可自己改Connection conn= DriverManager.getConnection(url);String content=request.getParameter("content");String filename=request.getParameter("image");FileInputStream str=new FileInputStream(filename);String sql="insert into test(id,content,image) values(1,?,?)"; PreparedStatement pstmt=dbconn.conn.prepareStatement(sql);pstmt.setString(1,content);pstmt.setBinaryStream(2,str,str.available());pstmt.execute();out.println("Success,You Have Insert an Image Successfully");%>下面我写一个测试image输出的例子看我们上面程序写的对不对,testimageout.jsp的内容如下:<%@ page contentType="text/html;charset=gb2312"%><%@ page import="java.sql.*" %><%@ page import="java.util.*"%><%@ page import="java.text.*"%><%@ page import="java.io.*"%><html><body><%Class.forName("org.gjt.mm.mysql.Driver").newInstance();Stringurl="jdbc:mysql://localhost/mysql?user=root&password=&useUnicode=true&characterEncoding= 8859_1";//其中mysql为你数据库的名字,user为你连接数据库的用户,password为你连接数据库用户的密码,可自己改Connection conn= DriverManager.getConnection(url);String sql = "select image from test where id=1";Statement stmt=null;ResultSet rs=null;try{stmt=conn.createStatement();rs=stmt.executeQuery(sql);}catch(SQLException e){}try {while(rs.next()) {res.setContentType("image/jpeg");ServletOutputStream sout = response.getOutputStream();InputStream in = rs.getBinaryStream(1);byte b[] = new byte[0x7a120];for(int i = in.read(b); i != -1;){sout.write(b);in.read(b);}sout.flush();sout.close();}}catch(Exception e){System.out.println(e);}%></body></html>你运行这个程序,你就会看到刚才你写入美丽的图片就会显示在你面前。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
本实例主要介绍如何将图片存入数据库。
将图片存入数据库,首先要在数据库中建立一张表,将存储图片的字段类型设为Image类型,用FileStream类、BinaryReader把图片读成字节的形式,赋给一个字节数组,然后用ADO.SqlCommand对象的ExecuteNonQuery()方法来把数据保存到数据库中。
主要代码如下:private void button1_Click(object sender, EventArgs e){openFileDialog1.Filter = "*jpg|*.JPG|*.GIF|*.GIF|*.BMP|*.BMP";if(openFileDialog1.ShowDialog()==DialogResult.OK){string fullpath =openFileDialog1.FileName;//文件路径FileStream fs = new FileStream(fullpath, FileMode.Open);byte[] imagebytes =new byte[fs.Length];BinaryReader br = new BinaryReader(fs);imagebytes = br.ReadBytes(Convert.ToInt32(fs.Length));//打开数据库SqlConnection con = new SqlConnection("server=(local);uid=sa;pwd=;database=db_05");con.Open();SqlCommand com = new SqlCommand("insert into tb_08 values(@ImageList)",con);com.Parameters.Add("ImageList", SqlDbType.Image);com.Parameters["ImageList"].Value = imagebytes;com.ExecuteNonQuery();con.Close();}}本实例主要介绍如何从数据库中把图片读出来。
实现本实例主要是利用SqlDataReader从数据库中把Image字段值读出来,赋给一个byte[]字节数组,然后使用MemoryStream类与Bitmap把图片读取出来。
主要代码如下:private void button1_Click(object sender, EventArgs e){byte[] imagebytes = null;//打开数据库SqlConnection con = new SqlConnection("server=(local);uid=sa;pwd=;database=db_05");con.Open();SqlCommand com = new SqlCommand("select top 1* from tb_09", con);SqlDataReader dr = com.ExecuteReader();while (dr.Read()){imagebytes = (byte[])dr.GetValue(1);}dr.Close();com.Clone();con.Close();MemoryStream ms = new MemoryStream(imagebytes);Bitmap bmpt = new Bitmap(ms);pictureBox1.Image = bmpt;}本实例主要介绍如何只允许输入指定图片格式。
用OpenFileDialog控件打开图片文件,只要将OpenFileDialog控件的Filter属性指定为特定的图片格式即可。
例如,打开.bmp文件的图片,主要代码如下:this.openFileDialog1.Filter = "bmp文件(*.bmp)|*.bmp";在用pictureBox控件输入图片时,要想统一图片大小,只需把控件的SizeMode属性值设为StretchImage即可,StretchImage值表示图像的大小将调整为控件的大小。
这样,图片的大小就统一了。
上一页首页下一页00000000000000000000000000000000000000000000000000000000000000000000000000000000 0000000下上传图片到数据库,并且读出图片首先在SQL Server中建立一个图片存储的数库表,ImageData Column为图象二进制数据储存字段,ImageContentType Column为图象文件类型记录字段,ImageDescription Column为储蓄图象文件说明字段,ImageSize Column为储存图象文件长度字段,结构如下:CREATE TABLE [dbo].[ImageStore] ([ImageID] [int] IDENTITY (1, 1) NOT NULL ,[ImageData] [image] NULL ,[ImageContentType] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,[ImageDescription] [varchar] (200) COLLATE Chinese_PRC_CI_AS NULL ,[ImageSize] [int] NULL) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]*///UpLoadImage.aspx程序内容如下:<%@ Page Inherits="UploadImage.UploadImage" SRC="UpLoadImage.cs" Language="C#"%><HTML><title>上传图片</title><BODY bgcolor="#FFFFFF"><FORM ENCTYPE="multipart/form-data" RUNAT="server" ID="Form1"><TABLE RUNAT="server" WIDTH="700" ALIGN="left" ID="Table1" cellpadding="0" cellspacing="0" border="0"><TR><TD>上传图片(选择你要上传的图片)</TD><TD><INPUT TYPE="file" ID="UP_FILE" RUNAT="server" STYLE="Width:320"ACCEPT="text/*" NAME="UP_FILE"></TD></TR><TR><TD>文件说明(添加上传图片说明,如:作者、出处)</TD><TD><asp:TextBox RUNAT="server" WIDTH="239" ID="txtDescription" MAINTAINSTATE="false" /></TD></TR><TR><TD><asp:Label RUNAT="server" ID="txtMessage" FORECOLOR="red"MAINTAINSTATE="false" /></TD><TD><asp:Button RUNAT="server" WIDTH="239" onCLICK="Button_Submit" TEXT="Upload Image" /></TD></TR></TABLE></FORM></BODY></HTML>//-------------------------------------------------------------------//UpLoadImage.cs程序内容如下:using System;using System.Web;using System.IO;using System.Data;using System.Data.SqlClient;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.HtmlControls;namespace UploadImage{public class UploadImage : Page{protected HtmlInputFile UP_FILE; //HtmlControl、WebControls控件对象protected TextBox txtDescription;protected Label txtMessage;protected Int32 FileLength = 0; //记录文件长度变量protected void Button_Submit(System.Object sender, System.EventArgs e) {HttpPostedFile UpFile = UP_FILE.PostedFile; //HttpPostedFile对象,用于读取图象文件属性FileLength = UpFile.ContentLength; //记录文件长度try {if (FileLength == 0){ //文件长度为零时txtMessage.Text = "<b>请你选择你要上传的文件</b>";}else{Byte[] FileByteArray = new Byte[FileLength]; //图象文件临时储存Byte数组Stream StreamObject = UpFile.InputStream; //建立数据流对像//读取图象文件数据,FileByteArray为数据储存体,0为数据指针位置、FileLnegth 为数据长度StreamObject.Read(FileByteArray,0,FileLength);//建立SQL Server链接SqlConnection Con = new SqlConnection("Data Source=Localhost;Initial Catalog=testdb;User ID=sa;Pwd=;");String SqlCmd = "INSERT INTO ImageStore (ImageData, ImageContentType, ImageDescription, ImageSize) valueS (@Image, @ContentType, @ImageDescription, @ImageSize)";SqlCommand CmdObj = new SqlCommand(SqlCmd, Con);CmdObj.Parameters.Add("@Image",SqlDbType.Binary, FileLength).value = FileByteArray;CmdObj.Parameters.Add("@ContentType", SqlDbType.VarChar,50).value = UpFile.ContentType; //记录文件类型//把其它单表数据记录上传CmdObj.Parameters.Add("@ImageDescription", SqlDbType.VarChar,200).value = txtDescription.Text;//记录文件长度,读取时使用CmdObj.Parameters.Add("@ImageSize", SqlDbType.BigInt,8).value = UpFile.ContentLength;Con.Open();CmdObj.ExecuteNonQuery();Con.Close();txtMessage.Text = "<p><b>OK!你已经成功上传你的图片</b>";//提示上传成功}catch (Exception ex){txtMessage.Text = ex.Message.ToString();}}}}//----------------------------------------------------------------------//好了,图片已经上传到数据库,现在还要干什么呢?当然是在数据库中读取及显示在Web 页中啦,请看以下程序://ReadImage.aspx程序内容如下:/-----------------------------------------------------------------------<%@ Page Inherits="ReadImage.MainDisplay" SRC="ReadImage.cs"%>//----------------------------------------------------------------------//ReadImage.cs程序内容如下:using System;using System.Data;using System.Data.SqlClient;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.HtmlControls;namespace ReadImage {public class MainDisplay : System.Web.UI.Page {public void Page_Load(System.Object sender, System.EventArgs e) {int ImgID = Convert.ToInt32(Request.QueryString["ImgID"]); //ImgID为图片ID//建立数据库链接SqlConnection Con = new SqlConnection("Data Source=KING;InitialCatalog=testdb;User ID=sa;Pwd=;");String SqlCmd = "SELECT * FROM ImageStore WHERE ImageID = @ImageID";SqlCommand CmdObj = new SqlCommand(SqlCmd, Con);CmdObj.Parameters.Add("@ImageID", SqlDbType.Int).value = ImgID;Con.Open();SqlDataReader SqlReader = CmdObj.ExecuteReader();SqlReader.Read();Response.ContentType = (string)SqlReader["ImageContentType"];//设定输出文件类型//输出图象文件二进制数制Response.OutputStream.Write((byte[])SqlReader["ImageData"], 0,(int)SqlReader["ImageSize"]);Response.End();Con.Close();//很简单吧^_^}}}//--------------------------------------------------------------------//最后,我们当然要把它在Web页面显示出来啦//ShowImage.hml<html><body>这个是从数据库读取出来的图象:<img src="ReadImage.aspx?ImgID=1"><body></html>00000000000000000000000000000000000000000000000000000000000000000000000000000000 000000000000000000000000000000将图片插入数据库并使用读取出来的正确方作者:佚名文章来源:不详点击数:68 更新时间:2006-11-7书写本文是因为今天见到CSDN的首页上一篇存在明显失误的名为“在中从sqlserver检索(retrieve)图片”的文章。