网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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,移动开发
本月文章推荐
.怎 样 在APPLET 中 发EMAIL.
.Candle点亮你的Web应用(CandleRM.
.通过JCA实现企业级应用程序的“即.
.Java初学者讲堂:JavaBean简易入.
.如何在程序异常或正常退出JVM时执.
.Javascript实例教程(7) 利用Java.
.Java核心代码例程之:Servlet---.
.[JAVA100例]028、图片的处理.
.hibernate实践.
.实例方法与条件执行.
.类装入问题解密,第 1 部分: 类装.
.保持 EJB 技术的所有优点而不增加.
.Java入门-讨论String中三种加法的.
.秉承Java思路 开发易于移植的J2M.
.一年Java之路的回顾,反思以及展.
.如何寻一个类X实例中类的物理所在.
.spring阶段性的一点感受.
.为什么程序员不应调用“sun”包.
.用Java实现的一个C/S完整聊天程序.
.Java手机软件图形界面API之Form相.

技巧-优化Derby数据库

发表日期:2008-1-5


摘要:
    Derby这个完全Java开发的开源的数据库也不例外,因此你必须保证它不会成为你程序的一个瓶颈。尽管人们可以在Derby的手册中找到关于这个话题全面的资料,我还是想更详尽的关注一下这些问题,基于我的经验提供一些具体的例子。

本文将着重于那些由在大的数据表中选择查询数据而产生的程序性能问题。数据库在操作少量测试数据和大量数据的时候,表现行为上有很大的差异。通常,在开发过程前期,人们不会关注数据库性能的问题,但是随着时间的发展,人们必须采取一些措施来保证数据库在大量数据的情况下正常工作。

    Derby这个完全Java开发的开源的数据库也不例外,因此你必须保证它不会成为你程序的一个瓶颈。尽管人们可以在Derby的手册中找到关于这个话题全面的资料,我还是想更详尽的关注一下这些问题,基于我的经验提供一些具体的例子。本文将着重于那些由在大的数据表中选择查询数据而产生的程序性能问题。

    首先,有很多关于调整Derby属性(诸如页面大小和缓存大小等)的技巧。修改这些参数可以在一定程度上调整数据库的性能,但是在通常情况下,更主要的问题来自与你的程序和数据库的设计,因此,我们必须首先关注这些问题,最后再来考虑Derby的属性。

    在接下来的段落里,我将介绍一些能够优化程序中有问题部分的技术。但是,和其他性能优化操作一样,我们需要在优化前先测量并确认问题所在。


一个简单的例子

    让我们从一个简单的例子开始:假设我们Web程序中拥有一个“search/list”的页面,要处理一个有接近100,000行的表,并且那个表不是很小的(至少有10栏)。用简单的JDBC来写一个例子,这样我们可以专注在数据库和JDBC问题上来。这篇文章中介绍的所有准则对所有的面向对象的映射工具都适用。

为了使得用户能够列出一个大的表,通常使用下面简单的查询语句。
select * from tbl

对应的JDBC语句如下:
Class.forName("org.apache.derby.jdbc.ClientDriver").newInstance();Connection connection = DriverManager.getConnection (        "jdbc:derby://localhost:1527/testDb;");Statement stmt = connection.createStatement();ResultSet rs = stmt.executeQuery("select * from tbl");ArrayList allResults = new ArrayList();while (rs.next()) {        // Object-Relation mapping code to populate your        // object from result set row        DomainObject domainObject = populate(rs);        allResults.add(modelObject);}System.out.println("Results Size: " + allResults.size());

    在这儿,我们碰到了第一个问题。执行这样的代码,并产生100,000(或更多)个domain对象将肯定会导致java用完堆栈空间,产生一个“java.lang.OutOfMemoryError”的错误。对于初学者来说,我们首先必须找到一个方法来使得这个程序工作。

分页Result Sets

    随着程序中数据量的增多,你首先想到的应该做的事就是为特定的记录(通常是视图)提供分页支持。正如你在这个介绍性的例子中看到的,简单地去获取庞大的result sets很轻易导致 out of memory的错误。

    许多数据库服务器支持特定的SQL结构,它们可以用于获得一个查询结果的特定的子集。例如,在mysql中,提供了LIMIT和OFFSET要害字,它们可以用于select查询。因此,假如你执行类似下面的查询
select * from tbl LIMIT 50 OFFSET 100


上一篇:EJBCA 3.0 开源CA系统软件初探 人气:924
下一篇:原始模型模式 人气:625
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐