分享
 
 
 

JDBC高级应用二

王朝other·作者佚名  2006-12-26
窄屏简体版  字體: |||超大  

JDBC高级应用(二)

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

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

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

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

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

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

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

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

从吃饭到睡觉中间省略了实际的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().

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

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

new StringBufferInputStream(String s),记住了.

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

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

oracle,sql server是可以直接set的.

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

数据结构:

create table test(

name varchar(200),

content BLOB

);

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

//传入文件路径

InputStream in = new InputStream(new FileInputStream(f));

PreparedStatement ps = conn.prepareStatement("insert into test (?,?)");

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

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

ps.executeUpdate();

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

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

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

PreparedStatement ps = conn.prepareStatement("select * from test where name=?");

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

ResultSet rs = ps.executeQuery();

if(rs.next()){

InputStream in = rs.getBinaryStream("content");

}

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

写向文件:

DateOutputStream out = new DateOutputStream(new FileOutputStream("b.exe"));

写向页面:

response.reset();

response.setContType("类型");

ServletOutputSreamt out = response.getOutputSream();

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

byte[] buf = new byte[1024];

int len = 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:

URL u = new URL("file://a.exe");

String mime = u.openConnection().getContentType();

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

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有