新客网WWW.XKER.COM:致力做中国最专业的网络学院!
学院: 操作系统 - 网络应用 - 服务器 - 网络安全 - 工具软件 - 办公软件 - Web开发 - 数据库 - 网页设计 - 图形图像 - 媒体动画 - 硬件学堂 - 存储频道 - QQ专区
您的位置:首页 > 软件开发 > 数据库 > Oracle教程 > 正文:在Oracle下开发Java程序的经典问题解答

在Oracle下开发Java程序的经典问题解答

新客网 XKER.COM 2007-08-09 来源: limeinan 收藏本文

问题一:如保加载JDBC驱动程序:

 

正常我们加载驱动程序有三个途径:

 

1.Class.forName(String)这想当于classLoader一个String指定的类,在装载时把该驱动程序的静态内容都初始化,其实这时驱动程序类调用了DriverManager.registerDriver(driver)方法。

 

2.使用系统属性:System.getProperty().load(new FileInputStream("属性文件"));

 

在属性文件中指定jdbc.driver=drivername 这样的好处是可以同时加载多个JDBC,换数据库时不用访问Java源代码,只是修改属性文件。

 

3.直接registerDriver(driver)这种方法最可靠,可以在任何环境下使用。

 

1方法简单,但MS的JVM不能正确初始化。比如使用IE时在APPLET中就不能使用,应该用3的方法。但3)方法在灵活性方面不如2,可以根据环境综合考虑。

 

问题二:大对象存储

 

一般来说,大对象存储是把文件存到数据库中,当然也可以内存中的超大字符串。对于象图片这样的文件当然是用二进制存储,这里有很多误区,网络上的教程99%都是行不通的,

 

连SUN自己的文档都一直错误,虽然错误很小。按说二进制文件应该存为BLOB类型,但JBDC2并不能直接对BLOB存入二进制文件,如果你这样做,会得到一个IO而不是SQL异常,为此

 

花了我近两个小时才弄清楚。

 

如果要把一个二制文件存入Oracle,用标准的JDBC你就要用LONG ROW类型:

 

create table tb_file(name varchar(20),detail long row);

然后:

 

File file = new File("aaa.gif"); 
int fileLength =(int) file.length(); 
InputStream fin = new FileInputStream(file); 
PreparedStatement pstmt = con.prepareStatement
("insert into tb_file values(´aaa.gif´,?)"); 
pstmt.setBinaryStream (1, fin, fileLength); 
pstmt.executeUpdate();

 

共2页: 上一页 [1] [2] 下一页
收藏】 【评论】 【推荐】 【投稿】 【打印】 【关闭
发表评论
要记得去论坛讨论,点击注册新会员匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
随机推荐
实用信息推荐