IF Bedingung in SELECT Statement?

Status
Nicht offen für weitere Antworten.

lazoli

Mitglied
Schönen Abend Programmierer,

ich möchte eine If Bedingung in meine Select Statement einbauen, ist das irgendwie möglich?
Was mache ich falsch?

Ich möchte eine "Suche" implementieren und möchte nach Kontakte suchen, die ich in der GUI
eingegeben habe. d.h. wenn ich nach Vorname = 'Franz' suche, dann soll nach Franz
gesucht werden oder wenn ich Vorname = 'Franz' und PLZ= 90000 suche, dann sollen nach
diesen beiden gesucht werden, hoffentlich verständlich...

Hier der Code:
Code:
		rs = st.executeQuery("SELECT * FROM contact WHERE contact_id > 0 " +
				if (firstname.length() > 0) { + "AND first_name = '"+firstname+"'" + }
				if (lastname.length() > 0) { + "AND last_name = '"+lastname+"'" + }
				if (postcode != 0) { + "AND pcode_id = '"+postcode+"'" + }
				if (city.length() > 0) { + "AND city = '"+city+"'" + }
				if (contactstate != 0) { + "AND c_status = '"+contactstate+"'"}
			);

Danke für eure Bemühungen
Frohe Weihnachten
 

Tobias

Top Contributor
Code:
StringBuilder sql = new StringBuilder("SELECT * FROM contact WHERE contact_id > 0 ");

if (firstname.length() > 0) { sql.append("AND first_name = '").append(firstname).append("'"); }
if (lastname.length() > 0) { sql.append("AND last_name = '".append(lastname).append("'"); }
if (postcode != 0) { sql.append("AND pcode_id = '").append(postcode).append("'"); }
if (city.length() > 0) { sql.append("AND city = '").append(city).append("'"); }
if (contactstate != 0) { sql.append("AND c_status = '").append(contactstate).append("'"); }

rs = st.executeQuery(sql.toString());

mpG
Tobias

P.S.: Dein händisches Escapen ist nicht gerade die bestmögliche Variante, PreparedStatement wäre besser.
 
M

Mican

Gast
Code:
public ArrayList sucheKunde(String vorname,String nachname,int status) throws SQLException{
		
		
		ArrayList list = new ArrayList();
		
		//wenn nichts ausgewählt ist kommen alle kunden
		//wenn du willst das nichts kommt kannst du 1=0 schreiben
		String sql= "Select * from Kunde where 1=1 ";
		
		if(vorname.length()>0){
			sql=sql+" and kunde.vorname='"+vorname+"'";
		}
		if(nachname.length()>0){
			sql=sql+" and kunde.nachname='"+nachname+"'";
		}
		if(status > 0){
			sql=sql+" and kunde.status="+status;
		}
		
		Statement stmt = conn.createStatement();
		ResultSet rs = stmt.executeQuery(sql);
		while(rs.next()){
			//.... burda cos
			//list.add(kunde)
		}
		
		return list;		
	}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
T if-else Bedingung wird ignoriert Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
Lion.King if-Bedingung Java Basics - Anfänger-Themen 3
B Zuweisungen und Methodenaufrufe in Bedingung der while Schleife? Java Basics - Anfänger-Themen 2
Avalon Warum funktioniert eine Bedingung und eine andere nicht? Java Basics - Anfänger-Themen 2
L while Schleife mit 2 Bedingung endet nicht Java Basics - Anfänger-Themen 3
M Wie lassen sich Konstanten in Bedingung stellen? Java Basics - Anfänger-Themen 1
M Wie lassen sich Objektkonstanten initialisieren, wenn sie eine Bedingung erreichen? Java Basics - Anfänger-Themen 6
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
A Dividieren mit Bedingung? Java Basics - Anfänger-Themen 7
P Bedingung in Schleife wird nicht ausgeführt Java Basics - Anfänger-Themen 5
Dimax Collections groupingBy mit Bedingung Java Basics - Anfänger-Themen 11
H Frage zur if-Bedingung bzw switch case Java Basics - Anfänger-Themen 6
F Bedingung für Eingabe Java Basics - Anfänger-Themen 2
scratchy1 Variablen vertauschen wenn Bedingung "umgedreht" wird Java Basics - Anfänger-Themen 40
Hanschyo If Bedingung Fehler Java Basics - Anfänger-Themen 7
T Komischer Fehler mit einer if-Bedingung Java Basics - Anfänger-Themen 3
W while Schleife und Bedingung Java Basics - Anfänger-Themen 11
E if-Bedingung mit mehreren Möglichkeiten ? Java Basics - Anfänger-Themen 6
S DefaultTableCellRenderer mit Bedingung Java Basics - Anfänger-Themen 1
J Fehler abfangen mit einer Bedingung Java Basics - Anfänger-Themen 3
Z Verschachtelte If-Bedingung Java Basics - Anfänger-Themen 6
N Methode mit While-Schleife und If-Bedingung und Array-Initialisierung Java Basics - Anfänger-Themen 4
L (Integer) Liste nach aufsteigender Summe der Ziffern sortieren (mit Bedingung) Java Basics - Anfänger-Themen 8
I Welche Schleife/Bedingung nehme ich her Java Basics - Anfänger-Themen 5
C Compiler-Fehler Wird eine if Bedingung nach einer for-Schleife nach jeder Iteration überprüft? Java Basics - Anfänger-Themen 1
B Kann mir jemand diese Bedingung erklären Java Basics - Anfänger-Themen 5
L Methoden if Bedingung trotz Erfüllung, nicht angesprochen Java Basics - Anfänger-Themen 12
P Compiler-Fehler if Bedingung fehlerhaft Java Basics - Anfänger-Themen 7
X Schleife bis "Bedingung" ausführen Java Basics - Anfänger-Themen 13
TheMenox Verschachtelte If Bedingung Java Basics - Anfänger-Themen 4
M Erste Schritte if-Bedingung schlägt fehl Java Basics - Anfänger-Themen 4
T Eigene Bedingung in IF-Bedingung Java Basics - Anfänger-Themen 22
Ocram Variablen Vereinfachung einer Bedingung Java Basics - Anfänger-Themen 18
J Can't find symbol - Erstellung eines Objekts in if-Bedingung Java Basics - Anfänger-Themen 3
M Frage zu if-Bedingung Java Basics - Anfänger-Themen 1
F Erste Schritte If Bedingung in Schleife dynamisch erweitern Java Basics - Anfänger-Themen 4
J Wo liegt nur an dieser einfachen Bedingung mein Fehler? Java Basics - Anfänger-Themen 8
R for-Schleife bei erfüllter Bedingung beenden Java Basics - Anfänger-Themen 7
R if funktion ohne else - Bedingung trifft nicht zu, ausgabe nicht nachvollziehbar Java Basics - Anfänger-Themen 7
S if bedingung - Stunde und Minute vergleichen Java Basics - Anfänger-Themen 5
K If-Bedingung mit Wertzuweisung Java Basics - Anfänger-Themen 2
J Vererbung If-Bedingung im Konstruktor Java Basics - Anfänger-Themen 15
J Arrays prüfen und über if Bedingung ausgeben Java Basics - Anfänger-Themen 15
T if Bedingung Java Basics - Anfänger-Themen 16
MiMa for Schleife Bedingung Java Basics - Anfänger-Themen 4
M in jTable schreiben unter Bedingung Java Basics - Anfänger-Themen 3
J Erste Schritte Kurze Frage zu Listenern und If-Bedingung Java Basics - Anfänger-Themen 2
N Verifikation einer if-Bedingung Java Basics - Anfänger-Themen 9
P Variablen ArrayList mit Bedingung iterieren Java Basics - Anfänger-Themen 2
E if(Bedingung) Java Basics - Anfänger-Themen 9
L Erste Schritte Sollte ich hier lieber Cases verwenden oder wäre eine If-Bedingung besser? Java Basics - Anfänger-Themen 6
Anfänger2011 Wie bricht man alles ab wenn eine Bedingung nicht erfüllt ist? Java Basics - Anfänger-Themen 21
P Variablen Variable in if Bedingung anlegen, Wert zuweisen und diesen als Bedingung nutzen Java Basics - Anfänger-Themen 4
M Und Bedingung Java Basics - Anfänger-Themen 17
N Bedingung für Datentypen Java Basics - Anfänger-Themen 3
E if-Bedingung funktioniert nicht Java Basics - Anfänger-Themen 9
W Funktionsaufruf nach Bedingung Java Basics - Anfänger-Themen 3
S for schleife mit if bedingung Java Basics - Anfänger-Themen 21
S return(Bedingung) ? [mehrere Befehle] Java Basics - Anfänger-Themen 5
2 Bedingung bei Schleife Java Basics - Anfänger-Themen 23
E Methode in der Bedingung Java Basics - Anfänger-Themen 11
E if Bedingung Java Basics - Anfänger-Themen 4
H Sortierung eines String[][] mit Bedingung Java Basics - Anfänger-Themen 7
H Bedingung while-Schleife | integer number too large Java Basics - Anfänger-Themen 2
J Gibt es eine möglichkeit ähnlich wie .equals(bedingung1 ||bedingung ..n) ? Java Basics - Anfänger-Themen 5
I Potenzmenge mit Bedingung Java Basics - Anfänger-Themen 24
S If-Bedingung Java Basics - Anfänger-Themen 15
P Einfache Bedingung (?) in Java Java Basics - Anfänger-Themen 3
K Fragen zu If-Bedingung Java Basics - Anfänger-Themen 3
S bedingung in variable speichern? Java Basics - Anfänger-Themen 8
neurox Ergebnis der if-Bedingung weiter verwenden Java Basics - Anfänger-Themen 5
G If-Schleife läuft ohne erfüllte Bedingung Java Basics - Anfänger-Themen 13
K Logik in if-Bedingung Java Basics - Anfänger-Themen 2
S if anweisung wird ausgeführt egal ob bedingung true o. false Java Basics - Anfänger-Themen 2
S For Schleife, Bedingung Java Basics - Anfänger-Themen 4
S Wildcard-Bedingung Java Basics - Anfänger-Themen 10
G Probleme mit break hier; in if-Bedingung Java Basics - Anfänger-Themen 5
M Schleife abhängig von Bedingung Java Basics - Anfänger-Themen 5
G while Bedingung? Java Basics - Anfänger-Themen 6
L Bedingung immer false, auch wenn zwei Strings gleich sind Java Basics - Anfänger-Themen 11
M Kleine Frage zu If-Bedingung Java Basics - Anfänger-Themen 4
Bierhumpen String Bedingung. Java Basics - Anfänger-Themen 8
M Comparable - Bedingung erzwingen Java Basics - Anfänger-Themen 3
R Klassen nach Bedingung laden Java Basics - Anfänger-Themen 22
G Compiler sieht die Bedingung nicht! Java Basics - Anfänger-Themen 5
W if Bedingung mit "Außer" Java Basics - Anfänger-Themen 4
berserkerdq2 sqllite in Java, wenn ich mache select count(*) ..., erhalte ich dann nur die gezählte Anzahl oder werden auch die Tabellen ausgegeben? Java Basics - Anfänger-Themen 2
E Select nimmt nicht alle Where /AND befehlen an Java Basics - Anfänger-Themen 4
D jsoup.select findet keine elemente Java Basics - Anfänger-Themen 2
O Checkboxen de-/select all Java Basics - Anfänger-Themen 4
B Tabellennamen mit Select auslesen Java Basics - Anfänger-Themen 17
K In MySQL Select Variablen aus Java Programm benutzen Java Basics - Anfänger-Themen 8
J select-feld auswahl, jsp javascript Java Basics - Anfänger-Themen 2
C SELECT klappt INSERT klappt nicht!!!??? Java Basics - Anfänger-Themen 3
C OOP JDBC: Ausgabe ResultSet nach Select Java Basics - Anfänger-Themen 3
W select() in Java . Java Basics - Anfänger-Themen 2
J Aktualisierungsabfrage mit SELECT Java Basics - Anfänger-Themen 2
C SQL: SELECT MAX - zwei Werte? Java Basics - Anfänger-Themen 3
G anz. zeilen einer db-tabelle holen? ohne select * from? Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben