gpt4 book ai didi

java - 使用 MySQL 连接器的 Java Servlet 中的 XML 响应缓慢

转载 作者:行者123 更新时间:2023-12-01 17:39:02 24 4
gpt4 key购买 nike

我创建了一个 Java Servlet,它从 mySQL 数据库获取查询结果并以 XML 格式打印。问题是打印 xml 结果需要很长的时间,大约三分钟,而在我的 PHP 脚本中则需要 5 秒。

我的Servlet相关函数是:(运行查询并返回字符串变量中的 xml,然后将其打印到页面)

public String QueryResult(String query)
{
String retStr;
try {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection ("jdbc:mysql://"+this.host+":"+this.port+"/"+this.db, this.user, this.pass);
Statement stmt = conn.createStatement();
ResultSet rset = stmt.executeQuery(query);
ResultSetMetaData rsMetaData = rset.getMetaData();

retStr = "<Result>\n";
while (rset.next())
{
retStr += "\t<Item>\n";
for (int i=1;i<=rsMetaData.getColumnCount();i++)
{
retStr += "\t\t<"+rsMetaData.getColumnName(i)+">"+ rset.getString(i) + "</"+rsMetaData.getColumnName(i)+">\n";
}
retStr += "\t</Item>\n";
}
retStr += "</Result>\n";
stmt.close();
conn.close();
}
catch(Exception e)
{
return "<Result><Error>"+e.toString()+"</Error></Result>";
}
return retStr;
}

最佳答案

字符串连接:

首先,当速度很重要时,您不希望按照您的方式连接字符串。每次连接字符串时,您都会创建一个新字符串。

最好使用具有精心规划的容量的 StringBuilder,因为从您显示的代码片段来看,默认的 StringBuilder 可能无法满足您的需求。

另请参阅:

String, StringBuffer, and StringBuilder

Why to use StringBuffer in Java instead of the string concatenation operator

XML:

XStream is a simple library to serialize objects to XML and back again.

可能与您的性能问题无关,但可能会派上用场:XStream

“性能”确实出现在他们的功能列表中。

关于java - 使用 MySQL 连接器的 Java Servlet 中的 XML 响应缓慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3227583/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com