首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 图形图象-> 3DMAX教程
JDBC 高级数据类型的应用-JSP教程,数据库相关
作者:网友供稿 点击:464
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 
jdbc 2.0 引进了对应于sql_99的许多新对象,这些新对象有blob,clob,array,ref,结构化类型,distinct类型以及locator.
jdbc 3.0增加了boolean和datalink对象
插入这些高级数据类型到数据库中的主要手段是使用preparedstatement对象,读取主要是resultset对象.下面介绍怎么在数据库中读取和写入高级数据类型

1:blob和clob
blob: 二进制大对象(binary large object)即一个字节序列(比喻说一个mp3文件可以存储为一个blob)
clob:一个对varchar 或类似的列来说太长的字符串.
来自数据库的blob和clob数据可以通过java.sql.blob和java.sql.clob对象来操作.
resultset 和preparedstatement对象提供的处理这两种数据的方法如下
resultset : preparedstatement
blob getblob(int) void setblob(int ,blob)//第一个参数是preparedstatement中的占位符的索引,以下相同
blob getblob(string) void setclob(int ,clob)
clob getclob(int)
clob getclob(string)
使用preparedstatement.setblob(int,blob)我们可以用blob数据来设置准备语句中的占位符,并且可以通过执行sql语句把这些数据写入到另一个表中
如:
string sql="select blob_col from blob_table where id=?"//blob_colum ,id为blob_table 这个表的列名
preparedstatement ps=connection.preparestatement(sql);
ps.setint(1,1);
resultset rset=ps.executequery();
blob blob=null;
if(rset.next())
{
blob=rset.getblob(1);
}
上叙中blob只是持有一个指向数据库中这些二进制数据的引用.并不持有实际二进制数据,然后代码可以使用这个相同的引用把这些二进制数据写入到另外的一个表中:
sql="insert into blob_table_2 values(?)";
ps=connection.preparestatement(sql);
ps.setblob(1,blob);
ps.executeupdate();

jdbc 2.0中的blob和clob借口提供了一种从数据库中获取数据或写数据到数据库的手段,这个手段是通过从数据库中获得一个流(输入或者输出)对象.并从该流中读取数据或写入.
例:
outputstream out=null;
bufferedinputstream in=null;
file file=new file("****");
reslutset rset=statement.executequery(sql);//从查询语句中取得一个结果集
if(rset.next())
{
blob blob=rset.getblob(1);
out=((oracle.sql.blob)blob).getbinaryoutputstream();//jdbc 2.0不支持写数据到blob,因此我们用oracle的扩展
int buffersize==((oracle.sql.blob)blob).getbuffersize();
in=new bufferedinputstream(new fileinputstream(file),buffersize);
byte[] b=new byte[buffersize];
int count=in.read(b,0,buffersize);
//开始存储数据到数据库中
while(cout!=-1)
{
out.write(b,o,count);
cout=in.read(b,o,buffersize);
}
//数据写完
out.close();
in.close();
connection.commit();//提交改变
........
}
类似的,我们可以从blob中得到一个输入流,把blob数据写入到文件中去
inputstream in=blob.getbinarystream();
int buffersize =((oracle.sql.blob)blob).getbuffersize();
2:结构化数据类型
结构化数据类型类似于一个java对象.如下,我们用sql定义一个people类型
create or replace type people as object(name varchar,age int);//oracle数据库..
现在可以在任何地方使用使用people该数据类型

create table samples(sa_id number, curson people,sample blob);
现在我们可以使用setobject()和 getobject()来操纵这些数据类型
resultset : preparedstatement
object getobject(int) void getobject(int,object)
object getobject(string)
..........
例:public class people implements sqldata,serializable
{
......
}
map map=connection.gettypemap();
map.put("people",people.class);//people这个类必须在前面创建,t它必须为表中的每个列含有一个成员变量
string sql="insert into sample(sa_id,curson) values(?,?)";
people people=new people();
ps=connection.preparestatement(sql);
ps.setint(1,1);
ps.setobject(2,people);
int result=ps.executeupdate();
我们也可以从数据库中取得这个people对象
string sql="select * from sample where sa_id=1";
ps=connection.preparestatement(sql);
resultset rset=ps.executequery();
if(rset.next())
{
people people=(people)rset.getobject(2);
}
3:distinct 类型
distinct类型象一个内建类型的别名,我们可以这样定义这个类型
create type birthdate as date
由于这个新类型只是一个指向某个已有内建类型的别名,所以我们可以使用getdate()和setdate()的方法;
4:构造类型
array和ref object(引用对象)
resultset preparestatement
array getarray(int) void setarray(int ,array)
array getarray(string)
ref getref(int) void setref(int,ref)
ref getref(string)
array方法可以通过制定行索引和列索引来存取行值和列值. 该array对象还可以把数组做为一个resultset来返回.(resultset只是存取一组行中的那些列值的手段)
上面我们定义了一个people自定义类型和sample表.如果执行一个返回people列的查询,可以使用getref()的方法,我们将会得到一个指向该列中的那个prople对象的引用

5:datalink
jdbc 3.0的一个新功能,datalink对象描叙外部地存取到数据库上的数据
datalink值使用seturl()和geturl()来处理
resultset preparestatement
url geturl(int) void seturl(int ,url)
url geturl(string)




文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·jsp中如何获取客户端的浏览器和操作系统信息-JSP教程,Jsp/Servlet
·在.net安装程序中部署oracle客户端全攻略-.NET教程,VB.Net语言
·JDBC 高级数据类型的应用-JSP教程,数据库相关
·java关于日期的运算等处理方法-JSP教程,Java技巧及代码
·Java Socket编程中的一个秘密类-JSP教程,Java技巧及代码
·什么是Servlet-JSP教程,Jsp/Servlet
·JSP直连各类数据库大全-JSP教程,Jsp/Servlet
·catv同轴电缆连接问题及解决方法
·discreet发布3ds max7中文版sp1
·jsp页面调用applet实现人民币的大小写转换-JSP教程,Jsp/Servlet
最新文章
·快速推广行业b2b网站6个基本要点_营销推广
·photoshop处理荷花照片为水墨画特效_photoshop教程
·google adsense改变不了网站的命运_网赚技巧
·网页嵌入式广告是否也要遵守《物权法》?_网赚技巧
·google adsense似乎改进了“无效点击”判断算法_网赚技巧
·胡伟生:免费是基础 但会提供增值服务_站长访谈
·我赛网ceo张本伟:msn签名挂广告也卖钱_站长访谈
·广捷居郭吉军:边旅游边办网站年赚30万_站长访谈
·网站规划的心得:小领域,大市场_站长心得
·公布如何判断adsense无效点击的隐忧_google推广
相关主题
  • JDBC 3.0 有什么新特性-JSP教程,资料/其它
  • JDBC Connection Pool-JSP教程,数据库相关
  • JDBC 解决方案-JSP教程,Java基础
  • JDBC 示例(转)-JSP教程,Java基础
  • JDBC 入门-JSP教程,Java基础
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭