您的位置: 旅游网 > 情感

JDBC高级应用二

发布时间:2019-12-03 06:55:41

本来想继续谈JDBC的高级连结方式,事务模式.但发现关于大对象存储有很多人在问,所以

先来插入一节关于大对象存储的内容,然后再接着原来的思路写下去.

JDBC的大对象存储听起来复杂,其实如果你明白了原理以后,就非常简单,网上有关这方面的

教材很少,而SUN的文档中,我从1.2开始看到一在仍然是错误的,不知道写文档的人长脑子没

有,就那几行代码你试试不就知道了,这么多次重抄下来还是错误的.

大对象分类:一般来说,大对象分为:大的文本对象,比如一个很长的文本(请你要注意什么是

文本文件,什么是二进制文件)文件,或者是你定义的一个长字符串,比如你定义了:

Strings="我们要去吃饭了......................然后睡觉!";

从吃饭到睡觉中间省略了实际的10000000000000字,虽然你不会真的定义这么称的String,但

有时会从什么地方得到这样的String,要写到数据库中.

另一种就是大的二进制对象,象执行文件,图象文件等,注意,word,excel,ppt这些"带格式"的文

档都应该以二进制对象存储.

一般来说,数据库如果支持大对象存储,会有这几种类型的SQL数据类型:

BLOB,CLOCB,NLOB,也有的数据数只有一种BLOB,基本上是这样的:BLOB用来存放二进制文件,而

CLOB用来存放文本文件,NLOB是对多字节文本文件支持.假如你的文本文件是纯英文的,放在

BLOB中当然可以,也就是说它是以byte格式存储的,而多字节是以CHAR格式存储的.

同样对于这几种类型的文档,有几种相对应的存取方式:

setter:

利用PreparedStatement的setXXX方法,

setAsciiStream()方法用于写入一般的文本流.setBinaryStream()方法用于写入二进制流

而setUnicodeStream()用于写好UNICODE编码的文本,与此相对应的ResultSet中三个getter方法

用于取回:getAsciiStream(),getBinaryStream(),getBinaryStream().

对于文件本身,要把它作为一个流,只要newInputStream(newFileInputStream("文件路径"))

就可以了,但对于大的String对象,你不会写入文件再转换成输入流吧?

newStringBufferInputStream(Strings),记住了.

JDBC2以后提供了java.sql.BLOB对象,我不建议大家使用它,一是很麻类,二是容易出错,要先插

入一个空的BLOB对象,然后再填充它,实在没有必要,直接setXXX就行了,我试过,至少mysql,

oracle,sqlserver是可以直接set的.

好了,我们先看一个例子如何写入文件到数据库:

数据结构:

createtabletest(

namevarchar(200),

contentBLOB

);

Filef=newFile("a.exe");//先生成File对象是为了取得流的长度.FileInputStram可以直接

//传入文件路径

InputStreamin=newInputStream(newFileInputStream(f));

PreparedStatementps=conn.prepareStatement("insertintotest(?,?)");

ps.setString(1,"a.exe");

ps.setBinaryStream(2,in,(int)f.length());

ps.executeUpdate();

f的长度一定要做从long到int的转换,SUN的文档中好几版都没有改过来.就这么简单,当然,不同的

数据库存本身要设置它允许的最大长度,MYSQL默认只能传1M的文件,要修改参数原能存更大的文件.

如果要从数库中取得文件:

PreparedStatementps=conn.prepareStatement("select*fromtestwherename=?");

ps.setString(1,"a.exe");

ResultSetrs=ps.executeQuery();

if(rs.next()){

InputStreamin=rs.getBinaryStream("content");

}

得到in对象后,你可以进行任何处理,写向文件和写向页面只是out对象不同而已:

写向文件:

DateOutputStreamout=newDateOutputStream(newFileOutputStream("b.exe"));

写向页面:

response.reset();

response.setContType("类型");

ServletOutputSreamtout=response.getOutputSream();

得到out对象后,就可以输出了:

byte[]buf=newbyte[1024];

intlen=0;

while((len=in.read(buf))>0)

out.write(buf,0,len);

in.close();

out.close();

对于向页面输入,要设置什么样的ContType,要看你想如何输出,如果你想让对方下载,就设为

"application/octet-stream",这样即使是文本,图象都会下载而不会在浏览器中打开.如果你要想

在浏览器中打开,就要设置相应的类型,还要在容器的配置文件中设置支持这种文档类型的输出,但

对于很多格式的文件,到底要输出什么类型,其实就是HTTP的MIME集,比如图片:image/gif,当然你如

果你的文件扩展名(ext)不确定,你也不要用if(ext.equals("gif"))......这样来判断,我教你一个

技巧,我之所以说是技巧,是我没有在别的地方发现有人用这种方法,对我来说我是绝对不会把别人的

方法拿来说是我的技巧的:

构造一个file类型的URL,我们知道URL目前JAVA可以支持HTTP,FTP,MAILTO,FILE,LDAP等,从FILE类型

的URL就可以得到它的MIME:

URLu=newURL("file://a.exe");

Stringmime=u.openConnection().getContentType();

这样你就可以直接response.setContType(mime);而不用一个一个类型判断了.

好了,大对象存储就说到这儿,不同的数据仍然和些特殊的规定,不在此一一列举了.

黑龙江哪家医院治疗癫痫病
安徽治疗前列腺炎医院
天津治疗不孕不育费用
阜新市公安医院
南京新协和医院刘敏
猜你会喜欢的
猜你会喜欢的