当前位置:  开发笔记 > 编程语言 > 正文

用MySQL的JDBC真的很慢,不知道为什么

如何解决《用MySQL的JDBC真的很慢,不知道为什么》经验,为你挑选了1个好方法。

我的Java代码和MySQL数据库之间的连接速度很慢,我遇到了问题.我不知道瓶颈在哪里.

我的程序或多或少是一个聊天机器人.用户输入内容,我的程序将句子分成单词并将每个单词发送到数据库.如果它在那里找到了某些东西,则用户获得输出.数据库位于外部服务器上,但我也尝试连接到我旁边的电脑.两者都很慢.

我在另一个地方尝试了一次连接,然后我正常工作,那里很快,大部分时间.

我的SQL代码:

SELECT info.INFORMATION FROM INFORMATION info,INFO_SCHLUESSEL sch
WHERE LCASE(sch.SCHLUESSELWORT)LIKE'"+ input +"%'AND info.ID_INFO = sch.ID_INFO
Order BY info.PRIORITAET DESC LIMIT 1;

(只记得,如果它有助于理解sql代码:
schluessel = key
Schluesselwort =关键字
优先级=优先级)

我的Java数据库代码或多或少是标准的东西:

String driver ="com.mysql.jdbc.Driver";
String dbase ="jdbc:mysql:// bla";
String dbuser ="bla";
String dbpw ="bla";

的Class.forName(驱动器);
Connection con = DriverManager.getConnection(dbase,dbuser,dbpw);
语句stmt = con.createStatement();

ResultSet rs = stmt.executeQuery(query);
while(rs.next())
{
ergebnis = rs.getString("info.INFORMATION");
}

rs.close();
stmt.close();
con.close();

编辑:

我已经尝试了这个DBCP一段时间了,我似乎无法让它工作.它似乎和旧连接一样慢.这是我使用的网站提供的示例:

GenericObjectPool connectionPool = new GenericObjectPool(null);
ConnectionFactory connectionFactory = new DriverManagerConnectionFactory("jdbc:mysql:// bla","bla","bla");
PoolableConnectionFactory poolableConnectionFactory = new PoolableConnectionFactory(connectionFactory,connectionPool,null,null,false,true);
PoolingDriver driver = new PoolingDriver();
driver.registerPool( "示例",连接池);
Connection conn = DriverManager.getConnection("jdbc:apache:commons:dbcp:example");

Brian Agnew.. 7

我怀疑这是导致问题的连接设置.这需要多长时间:

Connection con = DriverManager.getConnection(dbase, dbuser, dbpw);

如果是这样,请查看Apache Commons DBCP,它允许您池化数据库连接.



1> Brian Agnew..:

我怀疑这是导致问题的连接设置.这需要多长时间:

Connection con = DriverManager.getConnection(dbase, dbuser, dbpw);

如果是这样,请查看Apache Commons DBCP,它允许您池化数据库连接.

推荐阅读
mobiledu2402851173
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有