在SQL Server中保存和输出图片

原创 2002年02月01日 08:57:00

介绍

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

    有时候我们需要保存一些binary data进数据库。SQL Server提供一个叫做image的特殊数据类型供我们保存binary dataBinary data可以是图片、文档等。在这篇文章中我们将看到如何在SQL Server中保存和输出图片。

 

建表

 

   为了试验这个例子你需要一个含有数据的table(你可以在现在的库中创建它,也可以创建一个新的数据库),下面是它的结构:

 

Column Name

Datatype

Purpose

ID

Integer

identity column Primary key

IMGTITLE

Varchar(50)

Stores some user friendly title to identity the image

IMGTYPE

Varchar(50)

Stores image content type. This will be same as recognized content types of ASP.NET

IMGDATA

Image

Stores actual image or binary data.

 

保存imagesSQL Server数据库

 

    为了保存图片到table你首先得从客户端上传它们到你的web服务器。你可以创建一个web form,用TextBox得到图片的标题,用HTML File Server Control得到图片文件。确信你设定了FormencType属性为multipart/form-data

 

Stream imgdatastream = File1.PostedFile.InputStream;

int imgdatalen = File1.PostedFile.ContentLength;

string imgtype = File1.PostedFile.ContentType;

string imgtitle = TextBox1.Text;

byte[] imgdata = new byte[imgdatalen];

int n = imgdatastream.Read(imgdata,0,imgdatalen);

string connstr=

((NameValueCollection)Context.GetConfig

("appSettings"))["connstr"];

SqlConnection connection = new SqlConnection(connstr);

SqlCommand command = new SqlCommand

("INSERT INTO ImageStore(imgtitle,imgtype,imgdata)

VALUES ( @imgtitle, @imgtype,@imgdata )", connection );

 

SqlParameter paramTitle = new SqlParameter

("@imgtitle", SqlDbType.VarChar,50 );

paramTitle.Value = imgtitle;

command.Parameters.Add( paramTitle);

 

SqlParameter paramData = new SqlParameter

( "@imgdata", SqlDbType.Image );

paramData.Value = imgdata;

command.Parameters.Add( paramData );

 

SqlParameter paramType = new SqlParameter

( "@imgtype", SqlDbType.VarChar,50 );

paramType.Value = imgtype;

command.Parameters.Add( paramType );

 

connection.Open();

int numRowsAffected = command.ExecuteNonQuery();

connection.Close();

 

从数据库中输出图片

 

    现在让我们从数据库中取出我们刚刚保存的图片,在这儿,我们将直接将图片输出至浏览器。你也可以将它保存为一个文件或做任何你想做的。

 

private void Page_Load(object sender, System.EventArgs e)

{

string imgid =Request.QueryString["imgid"];

string connstr=((NameValueCollection)

Context.GetConfig("appSettings"))["connstr"];

string sql="SELECT imgdata, imgtype FROM ImageStore WHERE id = "

+ imgid;

SqlConnection connection = new SqlConnection(connstr);

SqlCommand command = new SqlCommand(sql, connection);

connection.Open();

SqlDataReader dr = command.ExecuteReader();

if(dr.Read())

{

        Response.ContentType = dr["imgtype"].ToString();

        Response.BinaryWrite( (byte[]) dr["imgdata"] );

}

connection.Close();

}

 

    在上面的代码中我们使用了一个已经打开的数据库,通过datareader选择images。接着用Response.BinaryWrite代替Response.Write来显示image文件。

 

    希望您喜欢这些文章,如有任何意见和建议请致信webmaster@bipinjoshi.com

 

sql server数据库保存图片或者其他小文件

测试用sql server数据库保存图片或者其他小文件。 文件流字段用varbinary类型。 static void Main() { ...
  • pukuimin1226
  • pukuimin1226
  • 2013年12月26日 14:28
  • 8650

c#向SQL Server中存储图片并且再从数据库中读取图片

前言数据库课程设计答辩时,老师提出了如果数据是图片或者其他文件类型的时候,顿时觉得自己做的管理系统用到的较多的就是Char类型。于是,答辩结束后,就搜集资料学习,在查找资料的时候发现,有的一开始并不能...
  • sinat_27714067
  • sinat_27714067
  • 2016年07月01日 17:08
  • 4707

delphi使用ADO在sql数据库存取图片的方法

delphi使用ADO在sql数据库存取图片的方法 新手参考,老鸟绕行 我一直不认为能把代码写的和天书一样的程序员是好的程序员,那不过是因为我真的对delphi也就是略懂皮毛,太深了看不懂。 网上...
  • leavesguth
  • leavesguth
  • 2017年07月27日 11:33
  • 255

C++使用ADO存取图片

 在项目中,我们需要把事故简图上传到总服务器,以便每个客户端都能下载或者查看。在网上找了找,向Server2000存储图片代码比较多,从数据库中读取图片并显示也不少,但是把图片从数据库中二进制数...
  • eit520
  • eit520
  • 2014年06月10日 16:01
  • 3095

SQL Server视频总结

对SQL Server进行的一次深入学习,探索Select语句在SQL Sever中的重要组成作用及它的相关的附属知识。...
  • haofeijina
  • haofeijina
  • 2016年05月21日 17:33
  • 639

SQL 2008存储图片和读取图片

用一个Demo演示在SQL Server中如何实现对图片文件的存储和读取
  • quwenzhe
  • quwenzhe
  • 2014年06月17日 15:09
  • 2226

SQL Server 将查询结果导出插入(insert)语句的简单方式

SQL Server 将查询结果导出插入(insert)语句的简单方式
  • danny_style
  • danny_style
  • 2015年04月21日 09:46
  • 5292

C++读取与保存bmp图片文件编程实现

要用C++读取bmp图片文件,首先要弄清楚bmp图片文件的结构。可以参考这篇文章:http://blog.csdn.net/xiajun07061225/article/details/5813726...
  • libo601675378
  • libo601675378
  • 2014年11月23日 18:51
  • 6458

使用SQL Server Profiler跟踪数据库

1、找到SQL Server Profiler并登录 位置:单击开始--程序--Microsoft SQL Server--性能工具--SQL Server Profiler 或者登录后在下图的...
  • xunzaosiyecao
  • xunzaosiyecao
  • 2014年03月28日 19:59
  • 2963

SQL server 2008不允许保存更改的解决办法

我重装系统后就安装了SQL Server2008R2,第一次使用时在修改表结构的时候经碰到这样一个警告【不允许保存更改。您所做的更改要求删除并重新创建以下表。您对无法重新创建的标进行了更改或者启用了“...
  • qinyf2015
  • qinyf2015
  • 2017年01月10日 08:17
  • 271
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在SQL Server中保存和输出图片
举报原因:
原因补充:

(最多只允许输入30个字)