Methoden Arraylist wird "überschrieben"

chuvak

Aktives Mitglied
Ich habe als Klassenvariable das definiert:
Java:
List spielerListe = new ArrayList();

In einer Funktion werden Mitspieler aus einer DB ausgelesen und in einer Schleife der Liste hinzugefügt. Wenn ich am Ende der Funktion (außerhalb der Schleife) abfrage, wieviele Elemente die Liste hat, erhalte ich entweder 1 oder 0, egal, wieviele Mitspieler aus der DB geholt wurden.
Ich habe das gefühl, dass die Schleife jedes Mal mit den neuen Einträgen überschrieben wird, sodass da nicht z.B. 3 Mitspieler sind, sondern nur 1.

Java:
// Ausschnitt aus der View, wo die Funktion in der DB aufgerufen wird:
String meldung = db.auslesen(anzahlSpieler, tfName[i].getText(), String.valueOf(tfPasswort[i].getPassword()));

// Ausschnitt aus der Klasse DB:

  public String auslesen(int anzahlSpieler, String user, String pass) {
    try {
      stmt = conn.createStatement();
      rs = stmt.executeQuery("SELECT * FROM SPIELER where username='" + user + "' AND password='" + pass + "'");

      meldung = " - Bitte überprüfen Sie Ihre Benutzerangaben.";
      while (rs.next()) {
        meldung = "";
        spielerListe.add(user);
        System.out.println("hinzugefügt");
      }

      rs.close();
      stmt.close();

    } catch (SQLException ex) {
      System.out.println("fehler beim auslesen");
    }

    System.out.println("anzahl " + this.spielerListe.size());
    return meldung;
  }

Die Ausgabe ist immer:
hinzugefügt
anzahl 1
hinzugefügt
anzahl 1


Weiß jemand, wo der Fehler liegt?
 

AmunRa

Gesperrter Benutzer
So wie der Code aussieht wird da wahrscheinlich wirklich nur ein spieler hinzugefügt daher ist nur einer in der List.

mehr kann ich nicht sagen, da ich weder den Inhalt der Datenbank kenne, aber auch nicht was du nach vor bzw. nach dem Aufruf dieser Methode machst
 

chuvak

Aktives Mitglied
Java:
package spiel;

import java.sql.*;
import java.util.ArrayList;
import java.util.List;

public class DB {

  Connection conn = null;
  Statement stmt = null;
  ResultSet rs = null;
  String tabelle;
  String[] spalten = null;
  int i = 0;
  Spieler spieler;
  Object Klasse;
  String option;
  String meldung = "";
  String[] spielerNamen;
  static List spielerListe = new ArrayList();
  boolean fehler = true;

  public DB() {
    verbinden();
  }

  public void verbinden() {

    //Treiber laden

    try {
      Class.forName("com.mysql.jdbc.Driver").newInstance();
    } catch (Exception ex) {
      System.out.println("Fehler beim Treiber-Laden");
    }

// Verbindungsaufbau
    try {
      conn = DriverManager.getConnection("jdbc:mysql://localhost/spiel?user=root");
    } catch (SQLException ex) {
      System.out.println("SQLException: " + ex.getMessage());
      System.out.println("SQLState: " + ex.getSQLState());
      System.out.println("VendorError: " + ex.getErrorCode());
    }
  }

  public String dbRegistrieren(String user, String pass) {
    try {
      stmt = conn.createStatement();
      stmt.executeUpdate("INSERT INTO spieler (username, password) VALUES ('" + user + "', '" + pass + "')");
      stmt.close();
      meldung = "<html>Die Registrierung war erfolgreich!<br>Sie können Sie jetzt mir Ihren Benutzerdaten anmelden!</html>";

    } catch (SQLException ex) {
      System.out.println("fehler beim schreiben");
      meldung = "Etwas lief bei Ihrer Registrierung schief...";
    }
    return meldung;
  }

  public String auslesen(int anzahlSpieler, String user, String pass) {
    spielerNamen = new String[anzahlSpieler];
    try {
      stmt = conn.createStatement();
      rs = stmt.executeQuery("SELECT * FROM SPIELER where username='" + user + "' AND password='" + pass + "'");

      while (rs.next()) {
        fehler = false;
        spielerListe.add(user);
        System.out.println("hinzugefügt");
      }

      rs.close();
      stmt.close();

    } catch (SQLException ex) {
      System.out.println("fehler beim auslesen");
    }
    if (fehler == true) {
      meldung = " - Bitte überprüfen Sie Ihre Benutzerangaben.";
      spielerListe.clear();
    } else {
      if (spielerListe.size() == spielerNamen.length) {
        System.out.println("alles richtig!");
        meldung = "OK";
      }
    }
    System.out.println("anzahl " + spielerListe.size());
    return meldung;
  }

  public void beenden() {
    try {
      conn.close();
      conn = null;
    } catch (SQLException ex) {
      System.out.println("Fehler beim Schließen");
    }
  }
}
 

ARadauer

Top Contributor
Grundsätzlich ist ja dein DB sowas wie ein DatenZugriffsObjekt (DAO), ich würde da drinnen überhaupt keine List spielerListe machen.
Irgendetwas ließt eine Spieler ein um diese an zu zeigen usw da würde ich die liste hingeben.
Aber generell sollte es funktionieren auch wenn die Liste nicht static ist. Weißt du was static bedeuet? Wird irgendwo immer wieder new DB() aufgerufen?

Ich verstehe auch nicht genau was die auslesen Methode machen soll. Beschreib mal was genau diese Methode macht. Die ließt einen Spieler mit Namen, merkt sich die in einer Liste und wenn einer nicht gefunden wurde leert sie die liste ??? Da geschiet zu viel...Ich würde einfach zwei Methoden machen, eine ließt eine Liste von Spielern und eine ließt einen bestimmten...
bzw wie hängt eigentlich so ein Spieler mit dem usernamen zusammen?
 
D

despikyxd

Gast
führe doch dein query mal z.b. in phpMyAdmin aus ...
weil so wie ich das sehe fragst du nämlich nur nach einem bestimmten spieler ... und dann ist klar das dir die db nur diesen einen zurückgibt oder eben nichts wenn dieser nicht in der datenbank gefunden wird
siehe hierzu mal dein query : "SELECT * FROM `spieler` WHERE `username` = '"+user+"' AND `password` = '"+pass+"'"
du willst also alle zeilen die folgende bedingungen erfüllen
-alle spalten : SELECT *
-aus der tabelle spieler : FROM `spieler`
-wenn "username" und "password" den übergebenen argumenten entsprechen : WHERE `username` = '"+user+"' AND `password` = '"+pass+"'"
das du dann entweder 0 oder 1 erhälts liegt daran das entweder der user gefunden wird oder eben nicht ...

jetzt wäre die frage : was genau du haben willst ... daraus könnte man dann *mit der struktur deiner tabelle* n query zusammen bauen ... aber so wie dein query atm aufgebaut ist wirst du sicher nicht auf deine lösung kommen die du haben willst
 
F

Firephoenix

Gast
Hi,
alleine diese Zeile ist schon komisch:
Java:
spielerListe.add(user);
hier wird überhaupt nichts aus der db ausgelesen sondern einfach der String der als parameter an die Funktion übergeben wird, wieder und wieder in die Liste eingefügt.
Außerdem bietet es sich an Streams (bin nicht fit in den db-angelegenheiten, aber das sind doch Streams oder?) in einem finally-block zu schließen.
Eine Zusammenfassung was die Methoden machen sollen wäre vielleicht hilfreich ;)
Gruß
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J ArrayList<int[]> wird beim hinzufügen von werten komplett überschrieben warum? Java Basics - Anfänger-Themen 1
J Arraylist wird überschrieben? Java Basics - Anfänger-Themen 5
B Bungeecord | ProxiedPlayer wird nicht in ArrayList hinzugefügt Java Basics - Anfänger-Themen 1
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17
J ArrayList wird in JTable falsch angezeigt Java Basics - Anfänger-Themen 0
N ArrayList: Das zweite Element wird zur Liste nicht eingefügt nach dem zweiten request. Java Basics - Anfänger-Themen 3
thobren arraylist es wird nur der letzte Eintrag angezeigt Java Basics - Anfänger-Themen 2
F In ArrayList wird nicht der richtige Wert gespeichert Java Basics - Anfänger-Themen 6
B ArrayList wird nicht befüllt. Java Basics - Anfänger-Themen 5
N ArrayList wird immer um zwei Elemente erweitert Java Basics - Anfänger-Themen 9
krgewb ArrayList allgemein halten Java Basics - Anfänger-Themen 6
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J ArrayList vergleichen im spiel Mastermind Java Basics - Anfänger-Themen 2
Mugetsu35 ArrayList Update ohne Index Java Basics - Anfänger-Themen 6
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Z Java ArrayList speichert falsche Daten ab bzw. gibt falsche Daten aus? Java Basics - Anfänger-Themen 42
W if-Abfrage bei ArrayList-Methodenaufrufen - Wie löse ich das? Java Basics - Anfänger-Themen 6
W ArrayList und toString Java Basics - Anfänger-Themen 17
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
M 2d ArrayList durchgehen Java Basics - Anfänger-Themen 2
Blkckroll45 Arraylist Java Basics - Anfänger-Themen 6
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
berserkerdq2 Geht collections.sort bei allen? Linkedhashset, ArrayList, HashSet etc. Java Basics - Anfänger-Themen 4
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
D Arraylist mit Komplexen Datentyp Java Basics - Anfänger-Themen 3
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
volcanos List & ArrayList nach Familiennamen abfragen Java Basics - Anfänger-Themen 57
M static ArrayList in non-static Java Basics - Anfänger-Themen 12
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
M ArrayList<TreeNode<T>> fortlaufende Nummerierung der Elemente Java Basics - Anfänger-Themen 5
S ArrayList Username und passwort mit JTextField eingaben abgleichen Java Basics - Anfänger-Themen 10
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
F Erste Schritte Zahlenreihe von Arraylist in 3erBlöcke sortiert in neue Arraylist Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2
J ArrayList add methode selbst programmieren Java Basics - Anfänger-Themen 10
K Erste Schritte Wie schnell ist LinkedHashMap im Vergleich zur ArrayList, wenn alle Entries durchlaufen werden? Java Basics - Anfänger-Themen 47
thobren jtable arraylist Java Basics - Anfänger-Themen 12
N Exception beim Verwenden von Arraylist? Java Basics - Anfänger-Themen 10
P Schiebefix - ArrayList überschreibt Daten Java Basics - Anfänger-Themen 3
Zeppi OOP ArrayList Java Basics - Anfänger-Themen 2
P ArrayList Java Basics - Anfänger-Themen 4
L ArrayList auf 4 Elemente begrenzen Java Basics - Anfänger-Themen 56
C ArrayList sortieren nach bestimmten Buchstaben in den Wörtern Java Basics - Anfänger-Themen 13
S Arraylist<Object> mit verschiedenen Objects ausgeben Java Basics - Anfänger-Themen 3
J ArrayList auf bereits vorhanden eintrag prüfen Java Basics - Anfänger-Themen 5
M For Schleife/ArrayList Java Basics - Anfänger-Themen 12
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
L Längstes Element einer ArrayList ausgeben Java Basics - Anfänger-Themen 9
S Aus verschachtelter ArrayList auf einen Wert zugreifen Java Basics - Anfänger-Themen 4
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
M ArrayList in GUI ausgeben Java Basics - Anfänger-Themen 1
J Nur bestimmter Typ aus der ArrayList ausgeben. Java Basics - Anfänger-Themen 9
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
S Objekt aus Arraylist in andere Arraylist kopieren? Java Basics - Anfänger-Themen 2
C Sortieren einer ArrayList Java Basics - Anfänger-Themen 2
krgewb ArrayList von ArrayList Java Basics - Anfänger-Themen 2
R ArrayList Problem Java Basics - Anfänger-Themen 6
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
O Namen (mit Umlauten und ß) in einer ArrayList suchen Java Basics - Anfänger-Themen 5
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
R Methoden ArrayList clonen wirft exception Java Basics - Anfänger-Themen 3
S ArrayList in andere Klasse übernhemen Java Basics - Anfänger-Themen 5
M Letztes Element einer ArrayList Java Basics - Anfänger-Themen 12
B Objektverwaltung mit ArrayList in einer seperaten Klasse Java Basics - Anfänger-Themen 24
I Sortiert eine HashMap nicht gleich wie eine ArrayList? Java Basics - Anfänger-Themen 1
I ArrayList erstellen innerhalb einer Zeile? Java Basics - Anfänger-Themen 3
V Collections ArrayList mit Comparator sortieren Java Basics - Anfänger-Themen 16
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
F java.util.ArrayList Java Basics - Anfänger-Themen 3
M ArrayList - Objekt kopieren und ändern Java Basics - Anfänger-Themen 11
M Zugriff auf eine ArrayList in einer anderen Klasse Java Basics - Anfänger-Themen 4
P Arraylist zu einem Array bringen mit Verschachtelung Java Basics - Anfänger-Themen 11
N Methode mit einer Arraylist Java Basics - Anfänger-Themen 106
I ArrayList - Methode zum Speichern eines Eintrags in einer Datei Java Basics - Anfänger-Themen 17
H ArrayList Java Basics - Anfänger-Themen 7
D public ArrayList(Collection<? extends E> c); Java Basics - Anfänger-Themen 2
M JTextField in ArrayList speichern Java Basics - Anfänger-Themen 4
C ArrayList mit return zurückgeben Java Basics - Anfänger-Themen 13
K Zahlenfolge ArrayList Java Basics - Anfänger-Themen 3
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
I Klassen Eine ArrayList<Long>, die sich automatisch sortiert Java Basics - Anfänger-Themen 20
F Array in ArrayList ablegen Java Basics - Anfänger-Themen 3
V ArrayList Java Basics - Anfänger-Themen 1
Z Runden Arraylist Java Basics - Anfänger-Themen 9
X Frage zur einer ArrayList in einer ArrayList Java Basics - Anfänger-Themen 5
F Arraylist als Pfadausgabe Java Basics - Anfänger-Themen 10
L Daten aus ArrayList in Datenbank durchsuchen Java Basics - Anfänger-Themen 5
L Objekt aus Textdatei in ArrayList speichern Java Basics - Anfänger-Themen 4
M Problem mit ArrayList Java Basics - Anfänger-Themen 32
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben