您好,欢迎访问一九零五行业门户网

ASP.NET下向SQLServer2008导入文件实例操作方法

在microsoft sql server2008以后的版本中,将删除image数据类型。在新的开发工作中将不适用此数据类型,并打算修改当前使用此数据类型的应用程序,改用varbinary(max)数据类型。
asp.net向sql server导入文件主要用到fileupload控件的filebytes属性。该属性从fileupload控件所指定的文件返回一个字节数组 。
1.数据库准备
为了方便大家能够理解,这里我们只设计两个字段,一个是文件类型字段,字段名为filetype,另一个是存放文件内容字段,字段名为filecontent。创建数据库
,数据库名为varfile,语句如下:
create database varfile
go
创建表,表名为fileinout,语句如下:
use varfile
go
create table fileintou
(
filetype nvarchar(30) not null,
filecontent varbinary(max) null
)
2.添加控件
运行vs2008并新建一个网站,在页面default.aspx中添加一个fileupload控件,id 为fileupload1.同时添加三个button按钮,id分别为fileup和fileload。text属性分别设置为“上传文件”和“下载文件”。
3.添加代码
(1)添加命名空间,因为和sql server数据库连接,所以添加using system.data.sqlclient和using system.data命名空间。又因为要设置输出流的http的字符集为gb2312字符编码,所以添加using system.text命名空间。同时又因为要把导出文件强类型化为字符串,所以添加using system.collections.specialized命名空间。
(2)添加“上传文件”按钮的事件代码。当单击“上传文件”按钮后,获取fileupload控件所选择的文件的文件类型以及文件的字节数组插入数据库中。切换到设计视图,双击“上传文件”按钮,添加上传文件按钮事件代码,代码如下:
代码如下:
protected void fileup_click(object sender,eventargs e)
{
if(fileupload1.filename==string.empty)
{
response.write();
return;
}
string mailto:connstr=@%22data source=69f638102711447\sql2008;initial catalog=varfile;integrated security=ture; //数据库连接字符串
string the selected=fileupload1.filename; //获取上传文件的后缀名
string extension=theselected.substring(theselected.lastindexof(.)).tolower();
if(checkfiletype(extension)) //如果有指定的文件类型
{
string contenttype=getcontenttype(extension);
string sqlstr=insert into fileinout values(@filetype,@filecount); //上传文件的sql语句
string sqlstrclear=truncate table fileinout; //清空数据库sql语句
sqlconnection con=new sqlconnection(connstr); //实例化数据库连接对象
sqlcommand cmd=new sqlcommand(sqlstr,con); //实例化上传文件sql命令
sqlcommand cmdclear=new sqlcommand(sqlstrclear,con); //实例化清空数据库sql命令
//定义问价类型参数
cmd.parameters.add(new sqlparameter(@filetype”,slqdbtype.nvarchar,30));
cmd.parameters[@filetype].value=contenttype; //定义文件内容参数
cmd.parameters.add(new sqlparameter(@filecount,sqldbtype.nvarchar,30)); //将文件转化为字节数组作为@filecount的值
cmd.parameters[@filecount].value=fileupload1.filebytes;
con.open();
cmdclear.executenonquery(); //执行清空数据库命令
cmd.executenonquery(); //执行上传文件命令
}
}
(3)添加获取文件类型和获得文件导出方式的函数方法。首先查看所要上传文件类型是否在指定问价类型内,如果在,则可以直接导入文件,然后根据文件类型
获取此文件导出方式并存放在filetype字段中,代码如下:
代码如下:
public static bool checkfiletype(string type)
{
stringdictionary sd=new stringdictionary(); //实例化集合stringdictionary类
sd.add(.doc,application/msword);
sd.add(.ppt,application/vnd.ms-powerpoint);
sd.add(.xsl,application/vnd.ms-excel);
sd.add(.rtf,application/msword);
sd.add(.html,text/html);
sd.add(.htm,text/html);
sd.add(.txt,text/plain);
sd.add(.pdf,application/pdf);
return sd.containskey(type); //确定stringdictionary是否包含特定键
}
public static string getcontenttype(string extension) //获取输出文件方式
{stringdictionary sd=new stringdictionary();
sd.add(.doc,application/msword);
sd.add(.ppt,application/vnd.ms-powerpoint);
sd.add(.xsl,application/vnd.ms-excel);
sd.add(.rtf,application/msword);
sd.add(.html,text/html);
sd.add(.htm,text/html);
sd.add(.txt,text/plain);
sd.add(.pdf,application/pdf);
return sd[extension]; //返回对应键的值
}
(4)上传文件,选择一个pdf文件,单击上传文件按钮后,打开数据库中的fileinout表,如图所示可以看到。
其它类似信息

推荐信息