2013-04-22 9 views
5

मैं अब लगभग एक दिन और एक आधे के लिए इस पर काम कर रहा हूँ और मैं इस त्रुटि बाहर काम नहीं कर पा रहे "के बाद बंद कर दिया ResultSet ऑपरेशन की अनुमति नहीं दी।" मुझे नहीं पता कि परिणामसेट बंद क्यों किया जा रहा है। शायद आप में से कुछ मेरी मदद कर सकते हैं।जावा JDBC MySQL अपवाद:

MySQLDatabase:

package net.gielinor.network.sql; 

import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.ResultSet; 
import java.sql.SQLException; 
import java.sql.Statement; 

public abstract class MySQLDatabase { 

    private String host; 
    private String database; 
    private String username; 
    private String password; 
    private Connection connection = null; 
    private Statement statement; 

    public MySQLDatabase(String host, String database, String username, String password) { 
     this.host = host; 
     this.database = database; 
     this.username = username; 
     this.password = password; 
    } 

    public abstract void cycle() throws SQLException; 

    public abstract void ping(); 

    public void connect() { 
     try { 
      Class.forName("com.mysql.jdbc.Driver").newInstance(); 
      connection = DriverManager.getConnection(String.format("jdbc:mysql://%s/%s", host, database), username, password); 
      statement = connection.createStatement(); 
     } catch (Exception e) { 
      e.printStackTrace(); 
     } 
    } 

    public void ping(String table, String variable) { 
     try { 
      statement.executeQuery(String.format("SELECT * FROM `%s` WHERE `%s` = 'null'", table, variable)); 
     } catch (Exception e) { 
      connect(); 
     } 
    } 

    public ResultSet query(String query) throws SQLException { 
     if (query.toLowerCase().startsWith("select")) { 
      return statement.executeQuery(query); 
     } else { 
      statement.executeUpdate(query); 
     } 
     return null; 
    } 

    public Connection getConnection() { 
     return connection; 
    } 

} 

MySQLHandler

package net.gielinor.network.sql; 

import java.io.FileInputStream; 
import java.util.ArrayList; 
import java.util.List; 
import java.util.Properties; 

import net.gielinor.network.sql.impl.MySQLDonation; 

public class MySQLHandler extends Thread { 

    private static final MySQLHandler mysqlHandler = new MySQLHandler(); 

    public static MySQLHandler getMySQLHandler() { 
     return mysqlHandler; 
    } 

    private static List<MySQLDatabase> updateList; 
    private static String host; 
    private static String database; 
    private static String username; 
    private static String password; 

    @Override 
    public void run() { 
     while (true) { 
      for (MySQLDatabase database : updateList) { 
       try { 
        if (database.getConnection() == null) { 
         database.connect(); 
        } else { 
         database.ping(); 
        } 
        database.cycle(); 
       } catch (Exception ex) { 
        ex.printStackTrace(); 
       } 

       try { 
        Thread.sleep(10000); 
       } catch (Exception ex) { 
       } 
      } 
     } 
    } 

    private static void loadProperties() { 
     Properties p = new Properties(); 
     try { 
      p.load(new FileInputStream("./sql.ini")); 
      host = p.getProperty("host"); 
      database = p.getProperty("database"); 
      username = p.getProperty("username"); 
      password = p.getProperty("password"); 
     } catch (Exception ex) { 
      System.out.println("Error loading MySQL properties."); 
     } 
    } 

    public static String getHost() { 
     return host; 
    } 

    static { 
     loadProperties(); 
     updateList = new ArrayList<MySQLDatabase>(); 
     updateList.add(new MySQLDonation(host, database, username, password)); 
    } 

} 

MySQLDonation

package net.gielinor.network.sql.impl; 

import java.sql.ResultSet; 
import java.sql.SQLException; 

import net.gielinor.game.model.player.Client; 
import net.gielinor.game.model.player.PlayerHandler; 
import net.gielinor.game.model.player.PlayerSave; 
import net.gielinor.network.sql.MySQLDatabase; 

public final class MySQLDonation extends MySQLDatabase { 

    public MySQLDonation(String host, String database, String username, String password) { 
     super(host, database, username, password); 
    } 

    @Override 
    public void cycle() throws SQLException { 
     ResultSet results = query("SELECT * FROM `gieli436_purchases`.`donations`"); 
     if (results == null) { 
      return; 
     } 
     while (results.next()) { 
      String username = results.getString("username").replace("_", " "); 
      System.out.println("name=" + username); 
      Client client = (Client) PlayerHandler.getPlayer(username.toLowerCase()); 
      System.out.println(client == null); 
      if (client != null && !client.disconnected) { 
       int creditamount = results.getInt("creditamount"); 
       if (creditamount <= 0) { 
        continue; 
       } 
       handleDonation(client, creditamount); 
       query(String.format("DELETE FROM `gieli436_purchases`.`donations` WHERE `donations`.`username`='%s' LIMIT 1", client.playerName.replaceAll(" ", "_"))); 
      } 
     } 
    } 

    @Override 
    public void ping() { 
     super.ping("donations", "username"); 
    } 

    private void handleDonation(Client client, int creditamount) throws SQLException { 
     client.credits = (client.credits + creditamount); 
     client.sendMessage("Thank you for your purchase. You have received " + creditamount + " store credits."); 
     PlayerSave.save(client); 
    } 

} 

अपवाद यहां होती है:

: MySQLDonation भीतर जबकि पाश और वास्तविक स्टैकट्रेस में यह है 210
java.sql.SQLException: Operation not allowed after ResultSet closed 
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1055) 
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:956) 
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:926) 
    at com.mysql.jdbc.ResultSetImpl.checkClosed(ResultSetImpl.java:794) 
    at com.mysql.jdbc.ResultSetImpl.next(ResultSetImpl.java:7077) 
    at net.gielinor.network.sql.impl.MySQLDonation.cycle(Unknown Source) 
    at net.gielinor.network.sql.MySQLHandler.run(Unknown Source) 
इस जानकारी के साथ

मुझे कहना है कि यह काम करता है, मैं अपने संदेश और क्या नहीं खेल पाने लेकिन यह दोहराता उपयोगकर्ता जैसी क्वेरी से हटा दिया कभी नहीं है तो यह उन्हें अनंत पुरस्कार देता है। यदि आपको किसी और जानकारी की आवश्यकता है तो पूछने के लिए स्वतंत्र महसूस करें।

+1

आपकी क्वेरी फ़ंक्शन क्या करती है। यह परिणामसेट बंद कर रहा है। – shazin

+0

सार्वजनिक ResultSet क्वेरी (स्ट्रिंग क्वेरी) SQLException { फेंकता है तो (query.toLowerCase() startsWith ("का चयन करें")।) { वापसी statement.executeQuery (क्वेरी); } अन्य { statement.executeUpdate (क्वेरी); } वापसी शून्य; } "क्वेरी" है, यदि स्ट्रिंग बराबर होती है तो हम क्वेरी निष्पादित करते हैं; अन्यथा हम निर्दिष्ट क्वेरी के लिए एक अद्यतन के लिए भेजते हैं। – rmcmk

+0

MySQLDonation.ping कॉल super.ping जो सार है! यह कोड संकलित नहीं करता है ... – Aubin

उत्तर

16

जब आप Delete क्वेरी चलाते हैं, तो आप उसी Statement का उपयोग करते हैं जिसका उपयोग Select क्वेरी में किया गया था। जब आप उसी Statement पर फिर से निष्पादित करते हैं, तो पिछले ResultSet बंद हो जाता है।

इससे बचने के लिए, आप एक नया Statement हर बार एक क्वेरी निष्पादित बनाना चाहिए। तो MySQLDatabase कक्षा में connect() विधि से statement = connection.createStatement(); हटाने, और connection.createStatement() है कि कक्षा में सभी statement बदलें। आप निजी चर statement को पूरी तरह से हटाने का भी चयन कर सकते हैं।

आप इसके बारे में अधिक पढ़ सकते हैं here

+0

ठीक है, यह और अधिक समझ में आता है। क्या यह मेरी "हटाएं" क्वेरी होगी जिससे समस्या या तालिका में प्रारंभिक क्वेरी हो सकती है? – rmcmk

+0

इसकी हटाई गई क्वेरी। यदि आप इसे लूप से बाहर ले जाते हैं, तो आपका कोड काम करेगा, लेकिन मुझे विश्वास है कि तर्क सभी गलत होगा। –

+0

कैसा है? गहराई में थोड़ा और समझाते हुए मन?ठीक है, @ galuano1, मैंने _statement_ instance और "query" विधि को हटा दिया और प्रत्येक क्वेरी को अपना स्वयं का बयान दिया। – rmcmk

2

यह त्रुटि कुछ समय होती है जब हम diff के लिए समान कथन ऑब्जेक्ट का उपयोग करते हैं। प्रकार

स्टेटमेंट ऑब्जेक्ट्स की जांच करें;

संबंधित मुद्दे