Problem mit ArrayList<String> und Umlauten

BlackC

Mitglied
Hallo Javagemeinde,

ich hab mal wieder ein seltsames Problem. Ich lese aus einer MS SQL Server 2008 R2 -Datenbank eine Tabelle aus, die unsere Bundesländer enthält, und zwar wie folgt:

Java:
      public  ArrayList<String > getAllFederalState(){
         ArrayList< String > list = new  ArrayList< String >();
         try
         {
            String command = "EXEC [dbo].[usp_getAllFederalState] ";

            ResultSet rs = stmt.executeQuery(command);
            while(rs.next())
            {
                list.add(rs.getString("Land"));
            }
        }
        catch(SQLException se)
        {
            JFrame frame = new JFrame();
            String message = se.getMessage();
            JOptionPane.showMessageDialog(frame, message,"ERROR by getting federal state data ", JOptionPane.ERROR_MESSAGE);
        }
        return list;
     }

Wenn ich jetzt aber mit der ArrayList weiterarbeite, hab ich festgestellt, dass nach einem ü (bsp. Baden-Württemberg) ein Leerzeichen eingefügt wird (steht also "Baden-Wü rttemberg" in der ArrayList).
Nach Tests hab ich den Fehler darauf begrenzt, dass der String beim einfügen in der Liste ("list.add() ") verändert wird. Aus der Datenbank wird er richtig ausgelesen.

Weiß zufällig einer Rat?

MFG
BlackC
 

SamHotte

Top Contributor
Sicher, dass das Leerzeichen im
Code:
rs.getString("Land")
nicht schon drin ist? Trenne doch mal die beiden Befehle.
 

BlackC

Mitglied
Sicher, dass das Leerzeichen im
Code:
rs.getString("Land")
nicht schon drin ist? Trenne doch mal die beiden Befehle.

Danke für deine Hilfe, das hab ich jedoch bereits getan. Wenn ich die Befehle wie folgt trenne

Java:
...
while(rs.next())
            {
                String x  = rs.getString("Land");
                list.add(x);
            }
...

steht im x "Baden-Württemberg", schau ich aber nach dem hinzufügen während dem debuggen in die List, steht da "Baden-Wü rttemberg". ;(
 
N

nillehammer

Gast
Die add-Methode von ArrayList macht sowas nicht. Ich halte es für ausgeschlossen, dass der Fehler dort liegt. Ich würde eher vermuten, dass der Debugger den String falsch ausgibt. Siehst Du mit System.out.println das gleiche Verhalten?

Und dann noch ein kleiner Verbesserungsvorschlag für Deine Methode
[Java]
public List<String> getAllFederalState(){
List<String> list = new ArrayList<String>();
...
[/Java]
 

SamHotte

Top Contributor
Komisch ... ich hätte vermutet, dass der DB-Treiber ein Umlaut-Problem hat, denn die JVM sollte eigentlich keines haben. Beim Einfügen in die Datenbank gab's keine Probleme?
 

BlackC

Mitglied
Komisch ... ich hätte vermutet, dass der DB-Treiber ein Umlaut-Problem hat, denn die JVM sollte eigentlich keines haben. Beim Einfügen in die Datenbank gab's keine Probleme?

Ich hab die Daten mit dem SQL Server Management in die Tabelle eingefügt, daher kann ich nur sagen, das bei anderen Methoden die Umlaute richtig hingeschrieben werden.

@nillehammer: Herzlichen Dank für deinen Tipp :) Ich hab das x sowie den jeweiligen list-wert mit system.out.println ausgegeben und beides mal ist an der Stelle des Leerzeichen ein "?", was meines Wissens nach ein Fehler mit dem Unicode sein soll. Allerdings weiß ich nicht, wie ich das umgehen kann. In der Datenbank ist es ein nvarchar, welches nach der Doku UTF-8 sein soll. Wie muss ich das konvertieren bzw. was kann ich machen?

PS.: Trotzdem find ich es komisch,dass sowas Netbeans nicht richtig anzeigt ...:bahnhof:
 
Zuletzt bearbeitet:

SamHotte

Top Contributor
Dieses "SQL Server Management" kenne ich nicht, aber evtl muss man dem DB-Zugriff (auch beim Schreiben) erst deutsch beibringen ... Ich kenne diesen Effekt bislang nur von Textdateien, da muss man manchmal von ASCII auf ANSI oder UTF-8 umstellen.

Probier' doch mal, die Werte von Deinem Java-Prog aus selbst in die DB hineinzuschreiben.
 
N

nillehammer

Gast
Es hängt vom verwendeten DBMs ab, was man machen muss, um UTF8 einzuschalten. Bei MySql kann man beim Create-Stagement angeben, dass der Zeichensatz für die Tabelle oder gar die ganze DB UTF8 sein soll. Darüber hinaus gibt es einen jdbc-Connection-Parameter "enccoding" den man auf UTF8 setzen muss. Ähnliches gibt es bestimmt auch bei anderen Datenbanken.
 

BlackC

Mitglied
So, ich hab jetzt etwas rumexperimentiert und herausgefunden, dass wenn ich selber etwas in utf-8 hineinschreibe und es dann mit "getString" auslese, wird es richtig angezeigt. Desweiteren scheint es nur an dieser einen Tabelle zu liegen, da andere Tabellen mit Umlauten kein Problem haben ???:L

Die Tabelle hab ich mit anderen Tabellen verglichen und kein Unterschied festgestellt, außer dass ich die funktionierende Tabellen aus sql erstellt habe und die Tabelle "Bundesland" mit Hilfe des SQL-Server Managementsystem". Werd jetzt mal auch diese Tabelle automatisch generieren. Ansonsten bin ich mit meinem Latein langsam am Ende. ;(


EDIT: Das Problem lag wirklich an dem manuellen erstellen der Tabelle. Nachdem ich ein SQL-Script geschrieben habe und meine aktuelle Tabelle ersetzt habe, wirds richtig ausgelesen. Was mich noch interessieren würde ist, ob dass ein Bug bzw. von meiner Seite nur falsch konfiguriert ist.
Nochmal bei allen herzlichen Dank für eure Hilfe :)
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0
Tommy Nightmare Project Euler: Problem 22 Allgemeine Java-Themen 2
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
P Eclipse Projekt anlegen macht Problem Allgemeine Java-Themen 1
RalleYTN META-INF/services Problem Allgemeine Java-Themen 3
F Java Mail Problem: Authentifizierung wird nicht immer mitgeschickt Allgemeine Java-Themen 1
I Problem beim Aufrufen, von Objektmethoden/ -variablen Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben