我的Java代码和MySQL数据库之间的连接速度很慢,我遇到了问题.我不知道瓶颈在哪里.
我的程序或多或少是一个聊天机器人.用户输入内容,我的程序将句子分成单词并将每个单词发送到数据库.如果它在那里找到了某些东西,则用户获得输出.
数据库位于外部服务器上,但我也尝试连接到我旁边的电脑.两者都很慢.
我在另一个地方尝试了一次连接,然后我正常工作,那里很快,大部分时间.
SELECT info.@R_257_4045@ION FROM @R_257_4045@ION 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 =关键词
优先级=优先级)
String driver = “com.MysqL.jdbc.Driver”;
String dbase = “jdbc:MysqL://bla”;
String dbuser = “bla”;
String dbpw = “bla”;Class.forName(driver);
Connection con = DriverManager.getConnection(dbase, dbuser, dbpw);
Statement stmt = con.createStatement();ResultSet rs = stmt.executeQuery(query);
while (rs.next())
{
ergebnis = rs.getString(“info.@R_257_4045@ION”);
}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(“example”,connectionPool);
Connection conn = DriverManager.getConnection(“jdbc:apache:commons:dbcp:example”);
解决方法:
我怀疑这是导致问题的连接设置.这需要多长时间:
Connection con = DriverManager.getConnection(dbase, dbuser, dbpw);
如果是这样,请查看Apache Commons DBCP,它允许您池化数据库连接.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。