String über mehrere Zeilen

rumpel84

Mitglied
Hallo,

wie kann man einfach einen String über mehrere Zeilen schreiben, ohne jedesmal + und Anführungszeichen einfügen zu müssen?
Das nervt bei langen SQL Statements tierisch :-(
Java:
String sql = "SELECT * "
              + "FROM dual "
              + "WHERE 1=1";

In C# funktioniert es so:
Java:
String sql = @"SELECT * 
                    FROM dual 
                   WHERE 1=1";

Danke im Voraus
 

Zenic

Mitglied
Ich weiß nicht ob ich dein Problem jetzt richtig verstanden habe, aber wie wäre es mit einem Zeilenumbruch (\n)?
Bsp:
Java:
String sql = "SELECT * \nFROM dual \nWHERE 1=1";

Wobei es mich ehrlich gesagt wundert das er bei +"String" eine neue Zeile macht. Oder soll der String im Code über mehrere Zeilen geschrieben stehen?
 

Schumi

Bekanntes Mitglied
Ja, er meint es im Code. Eclipse macht das automatisch, wenn man beim Editieren innerhalb eines Strings ist und Return drückt. Ansonsten müsste man wohl den Delimiter des Compilers ändern... ob das sinnvoll ist bzw. geht?
 

Oli

Top Contributor
Hi,

in Visual Studio ist ein String erst dann beendet, wenn das schließende Anführungszeichen vorhanden ist. Zeilenumbrüche im Code werden in der Entwicklungsumgebung dargestellt, aber nicht im String übernommen.

In Eclipse ist das nur mit + und " möglich.


Was jetzt besser ist, kann ich auch nicht sagen. Ich hab mich an beides gewöhnt...

Grüße
 

Oli

Top Contributor
@ Zenic

Wenn du

String sql = "SELECT * \nFROM dual \nWHERE 1=1";

als Datenbankabfrage absendest wird es böse krachen ;-)
 

Oni

Top Contributor
Du könntest das Ganze auch so schreiben:

Java:
StringBuilder sb = new StringBuilder();
sb.append("SELECT * ");
sb.append("FROM dual ");
sb.append("WHERE 1=1");

String sql = sb.toString();

Hat auch den Vorteil das nicht soviel String-Object erzeugt werden.
 

Zenic

Mitglied
Kenn mich mit Datenbanken (noch) nicht aus, aber mir ist der Sinn der Darstellung im Code, über mehrere Zeilen nicht klar, deshalb habe ich das nicht in Betracht gezogen.

Zum Thema: Hab jetzt leider kein Eclipse hier und kann es deshalb nicht testen, aber kann das nicht die IDE für einen übernehmen?

Edit: Onis Vorschlag ist für die Performance von langen Statements sicher besser, aber Arbeitserleichterung ist das keine ;)
 
Zuletzt bearbeitet:

faetzminator

Gesperrter Benutzer
Mit SQL und Java sollte man sowieso Prepaired Statements verwenden. Die Query dazu würde sich noch in eine Property-Datei auslagern lassen und das Einfügen der Werte funktioniert da sowieso Zeile für Zeile. Somit wäre das Problem mit formatierten Statements behoben.
 

rumpel84

Mitglied
es geht nur darum, lange sql statements in der IDE darzustellen (Netbeans). \n hilft also nicht weiter.

Die statements müssen öfter geändert und zwischen IDE und DB Tool hin und her kopiert werden und es nervt dann jedesmal die ganzen + "" hinzuzufügen bzw. zu entfernen.
 
S

SlaterB

Gast
wenn du erstmal Hibernate mit HQL verwendest, kannst du das kopieren eh knicken ;)

Java kann das bisher nicht,
brauchbare Alternative wäre nur, die SQL-Texte in Textdateien auszulagern,
durch die Trennung fachlich vielleicht nicht ideal, aber zumindest technisch im Programm kein Nachteil,
wenn du dort einen String änderst, müsstest du kompilieren und neu starten,
wenn da nur
String sql = loadSQLFromFile(322);
steht, könnte die Textdatei der Eintrag 322 auch zur Laufzeit geändert werden
 
T

Thomas Anonym

Gast
brauchbare Alternative wäre nur, die SQL-Texte in Textdateien auszulagern

Wie willst Du denn dann die Sache mit Tabellennamen/Feldnamen sinnvoll behandeln? Ich weiß ja nicht wie der Poster das handhabt aber ich kenne keine Umgebung bei der "Tabelle.Feld" in einem SQL-String fix drin steht. Bei uns sieht das eher so aus:

Java:
String where = TblEmployee.EColumns.lastName.getName() + " like ...";

Pro Tabelle gibt es eine Klasse und die hat immer einen generierten Enum EColumns mit allen Columns und die wiederum haben dann eine getName() genauso wie die Tabelle Ihren Namen verrät. Anders ist man doch bei jeder DB-Änderung (Schreibfehler in Feldname ändern, ...) aufgeschmissen und darf stundenlang Textsuchen machen. So geht das über ein simples Refactoring.

Aber zurück zum Thema: Ich verwende auch die Version mit dem StringBuilder einfach weil es deutlich schneller ist als eine lange Kette von "xxx" + "xxx" + "xxx" + "xxx" + "xxx" + "xxx"!
 

FArt

Top Contributor
Hat auch den Vorteil das nicht soviel String-Object erzeugt werden.

Aber zurück zum Thema: Ich verwende auch die Version mit dem StringBuilder einfach weil es deutlich schneller ist als eine lange Kette von "xxx" + "xxx" + "xxx" + "xxx" + "xxx" + "xxx"!

Beides ist prinzipiell wahr, aber die Arbeit muss man sich nicht machen: der Compiler wandelt Stringkontatination mit + sowieso selbständig um... also nehme ich die Version, die prinzipiell weniger Arbeit macht und lesbarer ist ;-)
Also doch nicht wahr...
 

tfa

Top Contributor
Aber zurück zum Thema: Ich verwende auch die Version mit dem StringBuilder einfach weil es deutlich schneller ist als eine lange Kette von "xxx" + "xxx" + "xxx" + "xxx" + "xxx" + "xxx"!
Das ist genau gleich schnell, denn eine lange Kette von "xxx" + "xxx" + "xxx" + "xxx" + "xxx" + "xxx" wird vom Compiler durch einen StringBuilder ersetzt. Nur wenn man + innerhalb einer Schleife benutzt, ist das schlecht für die Performance.
Wenn man nur Stringkonstanten konkateniert wie im Beispiel oben, wird sogar gleich ein fertiger String in den Bytecode geschrieben. Der StringBuilder wird wegoptimiert.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
L String extrahieren mit Regular Expression über mehrere Zeilen hinweg Java Basics - Anfänger-Themen 1
P String über mehrere Zeilen definieren Java Basics - Anfänger-Themen 3
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
J Eintrag Combobox über einen String auswählen Java Basics - Anfänger-Themen 3
J Variablenzugriff über string Java Basics - Anfänger-Themen 18
H Methode über String Wert aufrufen Java Basics - Anfänger-Themen 8
J Aufruf einer Methode über einen String Java Basics - Anfänger-Themen 11
D Java doppelte Zahlen auch über 10 in einem String entfernen Java Basics - Anfänger-Themen 2
B Werte über Scanner in ein 3 dim String Array schreiben Java Basics - Anfänger-Themen 7
O Datentypen double in string über fileWriter... Java Basics - Anfänger-Themen 7
N Input/Output String über InputStreamReader übergeben Java Basics - Anfänger-Themen 4
G String über int sortierbar machen Java Basics - Anfänger-Themen 23
E Einen String auch über die Laufzeit hinaus speichern Java Basics - Anfänger-Themen 4
U int to String über Integer Java Basics - Anfänger-Themen 6
G Zweidimensinales String array über for Schleife beschreiben Java Basics - Anfänger-Themen 20
C string über server/client verbindung senden ? Java Basics - Anfänger-Themen 4
krgewb String mit Datumsangabe in Long umwandeln Java Basics - Anfänger-Themen 2
D String Groß/Kleinschreibung Ignorieren Java Basics - Anfänger-Themen 4
D Map<String, Integer> sortieren und der reinfolge nach die Glieder abfragen Java Basics - Anfänger-Themen 3
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
Kartoffel_1 String transformation Java Basics - Anfänger-Themen 7
H String-Operation replace() - Zeichenkette verdoppeln Java Basics - Anfänger-Themen 2
K String analysieren Java Basics - Anfänger-Themen 27
Beowend String zu Date parsen Java Basics - Anfänger-Themen 1
Beowend String auf Satzzeichen überprüfen? Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
I Sass Compiler und String erhalten? Java Basics - Anfänger-Themen 7
Avalon String in Double bzw. Währung konvertieren Java Basics - Anfänger-Themen 6
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J Schlüsselworte Prüfen, ob ein bestimmtes, ganzes Wort in einem String enthalten ist. Java Basics - Anfänger-Themen 6
N String überprüfen Java Basics - Anfänger-Themen 3
E String zerlegen aus args Java Basics - Anfänger-Themen 1
M Long-Typ in String-Änderung führt zu keinem Ergebnis bei großer Zahl Java Basics - Anfänger-Themen 11
Ostkreuz String Exception Java Basics - Anfänger-Themen 8
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
J String Filter Java Basics - Anfänger-Themen 5
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Größter zusammenhängender Block gleicher Zeichen im String Java Basics - Anfänger-Themen 1
XWing Randomizer mit einem String Java Basics - Anfänger-Themen 2
D 2D Char Array into String Java Basics - Anfänger-Themen 2
H Cast von Float nach String klappt nicht Java Basics - Anfänger-Themen 12
I Zerlegen von String Java Basics - Anfänger-Themen 3
B Beliebiger String gegeben Suche Datum in String Java Basics - Anfänger-Themen 6
I String Java Basics - Anfänger-Themen 4
I API - zurückgegebener JSON String lesen und in Entity konvertieren Java Basics - Anfänger-Themen 2
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
M Kommandozeilenparamter als EINEN String werten Java Basics - Anfänger-Themen 5
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
Substring in einem String finden Java Basics - Anfänger-Themen 13
BeginnerJava String mit vorgegebener Länge und Buchstaben erzeugen/ mit Leerstellen Java Basics - Anfänger-Themen 8
I Eindeutiger String mit maximaler Anzahl an Zeichen Java Basics - Anfänger-Themen 11
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
JavaBeginner22 Integer in String umwandeln Java Basics - Anfänger-Themen 7
HolyFUT JSON String in Java Object schreiben - Anführungszeichen rauskriegen? Java Basics - Anfänger-Themen 17
Fodoboo131 RegEx- Umwandlung von String in ausführbares Objekt/ Befehl Java Basics - Anfänger-Themen 9
HolyFUT Input/Output Leerzeichen aus String entfernen - klappt nicht! Java Basics - Anfänger-Themen 13
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
X Datentypen String.equals funktioniert nicht Java Basics - Anfänger-Themen 5
Alen123 String wiederholen mit Schleifen Java Basics - Anfänger-Themen 1
A String split funktioniert nicht, wenn mehr als 1 Ziffer vor dem Zeichen steht nach dem er trennen soll? Java Basics - Anfänger-Themen 4
T String splitten Java Basics - Anfänger-Themen 3
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
J Datentypen String in File konvertieren funktioniert nicht Java Basics - Anfänger-Themen 4
T Platzhalter in String? Java Basics - Anfänger-Themen 14
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
I String Kombination erstellen anhand fortlaufender Zahl (Vertragsnummer) Java Basics - Anfänger-Themen 13
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
P9cman Vokale in einem String überprüfen mittels Rekursion Java Basics - Anfänger-Themen 8
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
R Ein Multidimensionales String Array initialisieren und Deklarieren Java Basics - Anfänger-Themen 2
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
S String mit Int input vergleichen Java Basics - Anfänger-Themen 5
C String/Char-API Java Basics - Anfänger-Themen 13
U Char zu einem String machen Java Basics - Anfänger-Themen 1
B Anzahl Nullen uns Einsen in String ermitteln Java Basics - Anfänger-Themen 3
T Leerzeichen im String entfernen Java Basics - Anfänger-Themen 6
Jose05 Nullpointerexception bei Umwandlung von String zu int Java Basics - Anfänger-Themen 2
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
M String beim einlesen formatieren Java Basics - Anfänger-Themen 12
N null in String replacen Java Basics - Anfänger-Themen 16
R Compiler-Fehler JTable mit XML befüllen | The constructor JTable(Object[], String[]) is undefined Java Basics - Anfänger-Themen 10
M Eclipse kennt keine String Klasse mehr Java Basics - Anfänger-Themen 1
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
D String mit int multiplizieren? Java Basics - Anfänger-Themen 16
H Überprüfen ob String Array leer ist Java Basics - Anfänger-Themen 4
A Korrigierte <String> Liste zurückgeben Java Basics - Anfänger-Themen 22
C In String, Buchstaben ersetzen durch andere Buchstaben Java Basics - Anfänger-Themen 26

Ähnliche Java Themen

Neue Themen


Oben