网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.用 Java 反射构建更通用的业务委.
.Spring中的Template和Callback模.
.Hibernate入门 - Transaction.
.IsReady 属性.
.利用java本地拷贝文件及文件夹.
.用Servlets实现Web方式的文件下载.
.JBuilder2005 Servlet开发之开发.
.访问JAR和JAD文件中的属性.
.浅谈Java与C#的事件处理机制.
.如何在Applet中引用jar中的资源文.
.绿色和本地线程简单介绍.
.Jakarta Struts简介(一).
.Java 中 this 的使用.
.Test of the Java Skill(4).
.返回值过载.
.Java Socket网络编程初级入.
.JAVA规则 开发篇.
.专稿:实战EJB之四 开发实体CMP(.
.Apusic 应用服务器简介.
.用Java编写的记事本程序(3).

认识JDBC 2.0中的高级数据类型

发表日期:2008-1-5



  JDBC 2.0中提供了对SQL3标准中引入的新的数据类型,如Blob(binary large object)、Clob(character large object)、Array 对象、REF(对象参考,object reference)和 UDT(用户定义数据类型,user-defined datatype)等的支持。这些新的数据类型结合在一起,使得数据库设计人员可以创建更丰富的模式,并简化了对复杂数据的处理和持久化。

  例如,我们要向tbl_User表中插入用户的照片,这时就可以使用流将Blob对象导入数据库中:

String sql = "intsert into tbl_User values(?, ?)";
PreparedStatement pstmt = con.prepareStatement(sql) ;

File file = new File("C:/images/photo.jpg") ;
FileInputStream fis = new FileInputStream(file);

pstmt.setString(1, "John");
pstmt.setBinaryStream(2, fis, (int)file.length());

pstmt.executeUpdate();

pstmt.close();
fis.close();
  其中SQL语句的第一个参数为用户名,第二个参数为photo,它是一个Blob型对象。这样在将数据插入数据库之后,我们就可以用程序获取该数据了:

String sql = "select photo from tbl_User where username = ?";
PreparedStatement pstmt = con.prepareStatement(selectSQL) ;

pstmt.setString(1, "John");
ResultSet rs = pstmt.executeQuery() ;

rs.next();
Blob blob = rs.getBlob("photo") ;

ImageIcon icon = new ImageIcon(blob.getBytes(1, (int)blob.length())) ;
JLabel photo = new JLabel(icon);

rs.close();
pstmt.close();
  类似地,我们也可以对Clob对象进行相应的操作。下面是一个从 ASCII 流中直接将 Clob对象插入数据库中的例子:

String sql = "insert into tbl_Articles values(?,?)";
PreparedStatement pstmt = con.prepareStatement(sql) ;

File file = new File("C:/data/news.txt") ;
FileInputStream fis = new FileInputStream(file);

pstmt.setString(1, "Iraq War");
pstmt.setAsciiStream(2, fis, (int)file.length());

pstmt.executeUpdate();

pstmt.close();
fis.close();
  同样,我们也可以用类似的方法将Clob对象从数据库中取出:

String sql = "select content from tbl_Articles where title = ?";
PreparedStatement pstmt = con.prepareStatement(sql) ;

pstmt.setString(1, "Iraq War");
ResultSet rs = pstmt.executeQuery() ;

rs.next() ;
Clob clob = rs.getClob("content") ;

InputStreamReader in = new InputStreamReader(clob.getAsciiStream()) ;

JTextArea text = new JTextArea(readString(in)) ;

rs.close();
pstmt.close();
上一篇:JavaBean与EJB有何不同 人气:628
下一篇:JBoss中EJB的开发 人气:520
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐