快速业务通道

JavaBeans和关系数据库的镜像 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-25

String ur1="jdbc:odbc:sample";String query="SELECT * FROM PERSON";boolean more;try{Class.forName("sun.jdbc.odbc.jdbcOdbcDriver");Connection con = DriverManager.getConnection(ur1,"sandor","guest");Statement stmt = con.createStatement();ResultSet rs = stmt.executeQuery(query);While (more = rs,next()){int number = rs.getInt("PERSON#");String firstName = rs.getString("FIRST_NAME");String lastName = rs.getString("LAST_NAME");System.out.printIn(number + " " + firstName + " " + lastName);}rs.close();stmt.close();con.close();}catch(SQLException ex){ex.printStackTrace();}

JavaBeans和关系数据库的镜像(2)

时间:2008-05-07

清单1:一个应用了JDBC的SQL查询

这段编码的含义是:先装入SUN 的JDBC/ODBC驱动程序,然后与被jdbc:odbc:sample指定的数据库建立起一个关联,最后对该数 据库进行一个简单的SELECT查询。如果没有遇到查询异常(SQLException),程序将循环地从结 果集(Result Set)中每次抽出一条数据库记录,并将其显示在屏幕上。

好了,现在我们来看一看这段程序 还有哪些不足?在清单1的这类程序中,存在着两个根本性的错误:

1.这种编码用到了数量众多的 数据库meta-信息,而这些信息都只能手工编码到程序中。当你想要取一个数值时,你必须提前 知道你将取到的数值是一个整数、浮点数、还是一个双精度数。这将会使得编写一个可以处理任 何一个数据库的类变得十分困难;并且每一个数据库的细小调整都会逼你去仔细地检查和修改 程序。

2.数据库中的信息总是作为一 个单个的RecordSet(记录集)实例来传递,而这种实例并不是一个真正的对象。RecordSet类( 与其它的数据库类封装没什么差别)更象一个指针或游标,借助方法,它能够提供存取数据信息 的途径。RecordSet中的实例实际上并不包括信息,它们仅仅表示获得信息的方式。这正说明了 当你要调用另外的Record Set方法去获取某些真实的数据信息的时候,你必须通过Record Set去 做更多的工作(利用RecordSet.NEXT()去移动指针)。实际上,JDBC类的确仅仅传递这类联系松 散的字段。即使你完全了解数据库的所有内部细节,这也没有任何价值,因为在Java提供了存储 和处理信息的方法。

所以,理想的状态是,有一种好的 方法,能够逐一地从数据库中抽取记录或字段(通过Record Set),并且将取到的信息“填”入到新 生成的对象之中。

这一解决方式的关键在于关系数 据库(RDB)和面向对象的数据模型(ODB)之间的相似性。RDB中的表和ODB中的类的作用很相似, 而记录和对象也有着某些相同的属性。你可以将记录看作是用来初始化某个对象的数据元素的 数据组。如果你已将记录从数据库中抽取出来,就必须调用类构造函数来生成上面所说的对象。 若能够将每一条记录自动地传到适当的构造函数中,就可以轻而易举地由记录来构造对象。

在开发一个小的应用程序时,有可 能将每一个记录传递给某个构造函数,以此来生成新的对象。你可以经常利用对象参照来操纵 从数据库中抽取的任何数据。因为你通过Record Set所得到的每一个对象最终都 是java.lang.Object的扩充。你可以定义一个BibClass,使其具有各类的共同属性,Big Class类 操作将利用Javainstanceof算子来实时决定运行中所遇到的数据库信息,并且通过一个大 的switch选择,跳到相应的程序段中。

你也可以定义一个相似的带有多 个构造函数的BigClass,每个构造函数有差别不太大的调用参数。你可以 用BigClass(int,int),BigClass(int,float)等等,取决于你从Record

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号