`
java-xb
  • 浏览: 126858 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

小程序测试Mysql 和access数据库性能,引发了一些问题,寻求解决。

阅读更多
我在做一个特征词的数据挖掘小测试,我使用java+access+jdbc进行开发的。
需求如下:
有一个文本集,文本集就是许多txt文本,文本内容大致如下:
盛名/n  之下/f  ,/w  其实难副/i  。/w  哎/e  ,/w  垃圾/n  书/n  。/w 

文本格式基本都是词+词性标示,例如:垃圾+/n
文本集大小为1529,即1529个文本文件。
计算每一个词在文本集中出现的次数,有些词不需要计算。

我首先选用access数据库,因为是一个小型的统计,所以我选用了access,用的是jdbc+odbc访问数据库
建立两张表,设计如下:

keyword表  存放词的统计
create table keyword
  (
  Id 		int(4) auto_increment not null primary key,
  Name 		varchar(50) not null,       //词的名称
  Times  	         int(4),			//词在文件集中出现的次数
  ClassLabelId    int(4),			//词的词性标示id
  count	 	int(4)			//文本集大小
  ); 

stopword表    存放不需要进行统计的词
create table stopword
( 
  Id 		int(4) auto_increment not null primary key,
  Name   	         varchar(50) not null,  //词的名称
  ClassLabelId     int(4)
);

建表语句是我用mysql进行测试时写的。

我把每个表(对应一个类)写了他们的dao操作,即增删改查操作。每个操作使用了打开数据库连接,关闭数据

库连接操作。

写完程序,我运行了一下,感觉还行,就是速度超慢,花了近半个小时才把1529个文件给统计完,我后来进行

了代码重构。发现运行速度提高了一点,但是感觉还是慢,后来在网上找了许多关于提高速度的帖子,又把代码重构了一下,感觉变化不大,说实话我经验不多,我从来没见过统计一个文本集中词的出现次数就需要20分钟的程序
。我后来想到了是不是数据库存储速度的问题,所以我想用mysql试试,果然用mysql进行测试。
在用mysql进行测试时,遇到了mysql中文乱码问题,在网上搜搜了就解决了,大家可以看我发表的mysql中文乱码问题的帖子。
换成mysql后,一运行,发现速度很快,我很高兴,不过没等我高兴几分钟,程序就报错,错误如下:

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: The driver was unable to create a 

connection due to an inability to establish the client portion of a socket.

This is usually caused by a limit on the number of sockets imposed by the operating system. This 

limit is usually configurable. 

For Unix-based platforms, see the manual page for the 'ulimit' command. Kernel or system 

reconfiguration may also be required.

For Windows-based platforms, see Microsoft Knowledge Base Article 196271 (Q196271).
        at sun.reflect.GeneratedConstructorAccessor10.newInstance(Unknown Source)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance

(DelegatingConstructorAccessorImpl.java:27)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
        at com.mysql.jdbc.Util.handleNewInstance(Util.java:406)
        at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1074)
        at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2103)
        at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:718)
        at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:46)
        at sun.reflect.GeneratedConstructorAccessor6.newInstance(Unknown Source)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance

(DelegatingConstructorAccessorImpl.java:27)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
        at com.mysql.jdbc.Util.handleNewInstance(Util.java:406)
        at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:302)
        at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:282)
        at java.sql.DriverManager.getConnection(DriverManager.java:582)
        at java.sql.DriverManager.getConnection(DriverManager.java:185)
        at fc.common.DBManager.getMySqlConnection(DBManager.java:48)
        at fc.dao.KeywordDao.getByName(KeywordDao.java:82)
        at fc.common.FcManager.countWordTimes(FcManager.java:44)
        at fc.common.FcManager.Tongji(FcManager.java:309)
        at fc.common.FcManager.main(FcManager.java:387)
Caused by: java.net.BindException: Address already in use: connect
        at java.net.PlainSocketImpl.socketConnect(Native Method)
        at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
        at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
        at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
连接数据库失败
数据库连接失败
        at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
        at java.net.Socket.connect(Socket.java:529)
        at java.net.Socket.connect(Socket.java:478)
        at java.net.Socket.<init>(Socket.java:375)
        at java.net.Socket.<init>(Socket.java:218)
        at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:253)
        at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:280)
        at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2026)
        ... 15 more
Exception in thread "main" java.lang.NullPointerException
        at fc.dao.KeywordDao.getByName(KeywordDao.java:117)
        at fc.common.FcManager.countWordTimes(FcManager.java:44)
        at fc.common.FcManager.Tongji(FcManager.java:309)
        at fc.common.FcManager.main(FcManager.java:387)
Java Result: 1

错误提示大致是这样的:不能创建连接,数据库连接失败。我想是不是程序写错了,哪个地方没有打开连接或者关闭连接不对。
可是仔细一想,应该不是,如果是程序错了,那在刚开始就应该报错,因为我每计算一个文本都是调用同一个方法,都过了好多文本才报错,这样情况应该不存在,我是这么认为的。

我在网上也搜索类似的错误,果然有。看了几个帖子,发现都是说服务器没有设置连接池,需要一个连接池。

我很无奈,我就写了一个小测试程序,没有用到服务器,所以无法设置连接池。可能是我没经验,也许有那种不在服务器上的连接池,我搜了搜,没发现好例子,我放弃了连接池的思路,在搜索中我想到了hibernate,我又把程序改成用hibernate访问数据库。结果没有报错,而且速度很快,我高兴的甚至把我的兴奋传到群里。
我给群里说:hibernate速度比jdbc快。
结果,群里说:你是初学者吧,那是你jdbc写的有问题 等等。
我也感觉是我写的jdbc有问题,我想是不是网上有好的jdbc,结果没找到,如果谁有好的给我发一份 邮箱:zh_xb2007@126.com,谢谢了!!!
我查看了代码,发现程序中每读取一个词都进行两次或者三次打开连接和关闭连接,是不是频繁的打开连接和关闭连接造成的错误,是不是mysql不能承受这种频繁的打开或者关闭,为何不把这样的操作放在计算每个文本的模块里面,

对于一个文本内容,可以看做一个业务逻辑,我想是不是应该把打开数据库连接和关闭数据库连接放在一个业务逻辑里面。于是我把代码修改了一下,再次运行,结果:没有报错,顺利运行,而且速度也快。我又笑了,没白费力气。
后来我又把连接改回去了,又重新连接了access,还是那个思路:把打开数据库连接和关闭数据库连接放在一个业务逻辑里面。
结果令我吃惊,居然报错了,报错内容是:客户端工作量过大。我又晕了,难道数据库不能进行大批量的更新操作?
我在网上搜了搜这个错误,都是说odbc的问题,最终没有解决这个问题。
我只好把打开数据库连接和关闭数据库连接放在一个原子操作里面,即增删改查操作。结果没有报错,速度也没提升。


测试结果如下:mysql存取数据速度确实比access高,但是那个错误是不是由于没有连接池或者频繁打开关闭连接所致,acess报客户端工作量过大的错误,这些都还没搞懂。


我附件里面有要测试的一个文本集,里面分为正面和反面两个文件夹。加起来为一个文本集
有兴趣的可以进行测试下,看看怎么样,不懂需求的请回帖给我。

希望大家给指点,拍砖都行。谢谢了



  • xl.rar (255.7 KB)
  • 下载次数: 11
分享到:
评论
3 楼 lusx 2011-09-09  
可是你上传的附件是什么东东哦!
2 楼 lusx 2011-09-09  
我也遇到了这个问题。
1 楼 java-xb 2010-08-29  
自己顶一个,没人发表一下言论

相关推荐

    ACESS转换MYSQL

    总的来说,“ACESS转换MYSQL”是解决从小型Access数据库向大型MySQL数据库迁移问题的一个解决方案,旨在帮助用户无缝地过渡到更强大的数据库系统,从而满足日益增长的数据管理和应用需求。这种转换对于那些寻求更...

    绿色好用论坛代码ASP+ACCESS上传到空间就可以使用

    标题 "绿色好用论坛代码ASP+ACCESS上传到空间就可以使用" ...不过,由于使用了ACCESS数据库,当论坛规模扩大,用户和数据量增加时,可能需要考虑升级到更强大的数据库系统,如MySQL或SQL Server,以确保性能和稳定性。

    MySQL性能调优与架构设计

    通过对MySQL的基础架构、性能调优方法以及高可用性和可扩展性的设计原则进行深入了解,可以有效地提升数据库系统的整体性能和稳定性。此外,MySQL的发展历程也为其他开源项目的成长提供了宝贵的经验和启示。

    Builder中访问远程数据库的另一种途径

    ZEOSDBO(Zeos Database Objects)是一套开源数据库控件,专门用于直接访问多种类型的数据库,包括开源数据库(如MySQL、PostgreSQL、Interbase)和商业数据库(如Microsoft SQL Server、Oracle)。与传统的BDE+ODBC...

    EZDML V1.5 最好的小型建模工具 支持ACCESS

    1. **ACCESS支持**:EZDML V1.5对Microsoft Access的完美支持意味着用户可以直接在Access数据库上进行建模,这对于小型企业或个人项目尤其实用,因为Access具有易于使用和成本效益高的特点。 2. **MySQL支持**:...

    [基于ASP整站程序源码]英达免费资源个人网站程序(源码+数据库).rar

    【基于ASP整站程序源码】英达免费资源个人网站程序是针对ASP技术构建的一款完整网站解决方案,包含源代码和数据库文件,适用于个人或者小型企业建立自己的在线资源分享平台。这款程序的核心在于ASP(Active Server ...

    数据库的介绍

    - **Access数据库**:微软的一款桌面数据库管理系统,适用于小型应用。 - **SQLite**:一款轻量级的嵌入式数据库,广泛用于移动应用开发。 - **FoxPro数据库**:一款由微软公司开发的关系型数据库管理系统,特别适合...

    MySQL简介、安装、配置、主要命令参考马士兵MySQL简明教程视频借鉴.pdf

    我们平常说的数据库Oracle、 MS SQL Server、MySQL 、Sybase、FoxPro、Access 等等,都是属于DBMS 范畴。 MySQL 安装 在安装 MySQL 之前,需要准备好 Windows 操作系统,例如 9x、Me、NT 、2000、XP 或 Windows ...

    Telerik OpenAccess ORM Q1 2009 (2009年3月12日版本)

    Telerik OpenAccess ORM是Telerik公司推出的一款对象关系映射(Object-Relational Mapping,简称ORM)工具,它旨在简化.NET应用程序与数据库之间的交互,提供了一种更为高效、灵活的数据访问解决方案。 ### 关于...

    基于Java的理发店管理系统的设计与实现源码数据库.zip

    9. **测试与优化**:在开发过程中,进行单元测试、集成测试以及性能测试,确保系统的稳定性、可靠性和高效性。同时,根据实际使用反馈进行持续优化,提升用户体验。 总的来说,这个基于Java的理发店管理系统展示了...

    一个简单的论坛软件

    2. **Access数据库**:Access数据库系统是Microsoft Office套件的一部分,它提供了一个图形用户界面和关系数据库引擎,使得创建和管理数据库变得简单。对于小型论坛这样的应用,Access的灵活性和易用性使其成为合适...

    c++课程设计小词典

    在这个小词典中,可能使用了ODBC接口来连接到一个特定的数据库系统,如MySQL、SQLite或MS Access,以存储和检索词汇数据。开发者可能创建了一个数据表,包含单词、定义、例句等字段,以便用户进行查询和学习。 文件...

    小信工作室全站程序

    9. **数据库集成**:全站程序可能依赖于某种数据库系统,如MySQL、SQL Server或Access,用于存储和管理网站数据。在使用前,需要正确配置数据库连接字符串。 10. **测试与优化**:在实际使用前,应对整个系统进行...

    ASP基于BS办公信息管理系统(源代码+论文).rar

    ADO提供了一种统一的方式来访问不同的数据源,包括Access数据库,使得ASP程序可以方便地读取、更新和删除数据。 SQL(Structured Query Language)是用于管理关系数据库的标准语言。在大型或高并发的办公信息管理...

    netbeans的小项目实例(初学可用)

    初学者需要掌握这些技巧,以便在遇到问题时能够有效地定位和解决问题。 9. **文档和社区支持**:NetBeans有详尽的官方文档和活跃的社区,初学者在遇到困难时可以查阅文档或在线寻求帮助。 总的来说,这个"NetBeans...

    DataBase plus plus-开源

    《DataBase++:开源C++库助力Access数据库操作》 ...对于那些寻求简单、快速接入Access数据库的项目,dbpp无疑是一个值得考虑的解决方案。同时,开源的特性也使得dbpp在不断迭代和优化中,有望满足更多开发者的需求。

    sql语法从入门到精通

    SQL语法的灵活性让它可以与各种数据库程序协同工作,例如MS Access、DB2、Informix、Microsoft SQL Server、Oracle、Sybase以及MySQL等。这些数据库系统都支持SQL标准,但也各自拥有特定的私有扩展。 RDBMS(关系型...

    ServU插件bbsftp v1.64

    除了上述特性,该插件还兼容多种数据库系统,包括Access、MsSql和MySQL,这为用户提供了更大的灵活性,可以根据现有数据库环境选择合适的集成方式。数据库支持使得插件能够高效地存储和检索大量用户信息和统计记录。...

    科美企业手机电脑建站系统通用版 v4.2

    同时,通过与Access数据库的结合,实现了数据的高效管理和维护,对于那些寻求低成本、高效能的企业网站解决方案的用户来说,是一个值得考虑的选择。然而,随着技术的发展,更现代的如PHP+MySQL或.NET+SQL Server等...

Global site tag (gtag.js) - Google Analytics