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

时间:2009-06-30 10:22:56

标签: java mysql jdbc

我的Java代码和MySQL数据库之间的连接速度很慢。我不知道瓶颈在哪里。

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

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

我的SQL代码:

  

SELECT info.INFORMATION FROM INFORMATION info,INFO_SCHLUESSEL sch
  LCASE(sch.SCHLUESSELWORT)LIKE'“+ input +”%'AND info.ID_INFO = sch.ID_INFO
  订购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);
  而(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”);

2 个答案:

答案 0 :(得分:6)

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

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

如果是这样,请查看Apache Commons DBCP,它允许您汇集数据库连接。

答案 1 :(得分:0)

嗯,我认为这需要对设计进行讨论。为了提高性能,您可以做一些事情。由于你不是在这里坚持任何东西,最好在一些自定义java对象,地图,列表或其他内容中预加载内存中的所有数据,然后对该单词进行内存中查找并获得结果。另一种方法可能是使用批处理语句,这样您就不会继续为每个单词创建和释放连接。哦,如果使用批处理语句,请确保将批处理大小设置为适当的数字,最好是素数