这是我第一次遇到这个错误.此代码基本上获取特定日期内销售的每件商品的总和.
有关解决此问题的任何提示吗?谢谢.
Run Code Online (Sandbox Code Playgroud)Statement statement = connection.createStatement(); String query = "SELECT itemcode, SUM(quantity) AS 'Total Sales Per Day' " + "FROM sales " + "WHERE real_pur_date = '" + date + "' " + "GROUP BY itemcode "; ResultSet rs = statement.executeQuery( query ); // this line gets the error / exception while( rs.next() ){ Vector row = new Vector(); row.add( rs.getString( "itemcode" ) ); row.add( rs.getInt( "Total Sales Per Day" ) ); dailyData.add( row ); } statement.close();
Exception in thread "AWT-EventQueue-0" java.lang.StackOverflowError
at com.mysql.jdbc.Util.handleNewInstance(Util.java:431)
at com.mysql.jdbc.ResultSetImpl.getInstance(ResultSetImpl.java:383)
at com.mysql.jdbc.MysqlIO.buildResultSetWithRows(MysqlIO.java:3140)
at com.mysql.jdbc.MysqlIO.getResultSet(MysqlIO.java:491)
at com.mysql.jdbc.MysqlIO.readResultsForQueryOrUpdate(MysqlIO.java:3118)
at com.mysql.jdbc.MysqlIO.readAllResults(MysqlIO.java:2288)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2709)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2677)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2627)
at com.mysql.jdbc.StatementImpl.executeQuery(StatementImpl.java:1556)
at posinventory.Controller.StatisticEngine.getDailyData(StatisticEngine.java:20)
at posinventory.Statistic.refreshTableDailyStat(Statistic.java:36)
at posinventory.Statistic.refreshTableDailyStat(Statistic.java:37)
at posinventory.Statistic.refreshTableDailyStat(Statistic.java:37)
at posinventory.Statistic.refreshTableDailyStat(Statistic.java:37)
Run Code Online (Sandbox Code Playgroud)
我不认为你包含的代码片段是问题所在.查看堆栈跟踪的底部,我看到Statistic.java:37显然多次调用自己.允许递归调用,但如果它们不受控制,则会导致堆栈溢出.看起来你有一个循环......
归档时间: |
|
查看次数: |
3008 次 |
最近记录: |