C-Sharp - String-Manipulation (SQL String manuell generieren)
Hallo,
Ich habe folgendes Problem in C#
In einer Anwendung soll eine SQL Abfrage angestoßen werden. die Felder die ich durchsuchen möchte kann mit CheckBoxen eingestellt werden.
Angenommen ich habe folgenden SQL String:
SELECT * FROM database WHERE field1='123' AND field2='456' AND field3='789' AND field4='abc' AND field5='def'"
Die CheckBoxen stehen für folgende Tabellen:
checkBox1 = field1
checkBox2 = field2
checkBox3 = field3
checkBox4 = field4
checkBox5 = field5
Wie bekomme ich es sauber hin, dass ich den String dynamisch generieren kann.
Dieser Weg fliegt selbstverständlich um die Ohren dank des WHERE und des AND
string SQL =
"SELECT * FROM database ";
if (checkBox1.Checked) { SQL += "WHERE field1='123' "; }
if (checkBox2.Checked) { SQL += "AND field2='456' "; }
if (checkBox3.Checked) { SQL += "AND field3='789' "; }
if (checkBox4.Checked) { SQL += "AND field4='abc' "; }
if (checkBox5.Checked) { SQL += "AND field5='def'"; }
Aber egal wie sehr ich drüber nachdenke, eine saubere Lösung will mir nicht einfallen wie ich das WHERE und vor allem die ANDs dynamisch einbeziehen kann.
Hat jemand eine Idee für mich?
Ich habe folgendes Problem in C#
In einer Anwendung soll eine SQL Abfrage angestoßen werden. die Felder die ich durchsuchen möchte kann mit CheckBoxen eingestellt werden.
Angenommen ich habe folgenden SQL String:
SELECT * FROM database WHERE field1='123' AND field2='456' AND field3='789' AND field4='abc' AND field5='def'"
Die CheckBoxen stehen für folgende Tabellen:
checkBox1 = field1
checkBox2 = field2
checkBox3 = field3
checkBox4 = field4
checkBox5 = field5
Wie bekomme ich es sauber hin, dass ich den String dynamisch generieren kann.
Dieser Weg fliegt selbstverständlich um die Ohren dank des WHERE und des AND
string SQL =
"SELECT * FROM database ";
if (checkBox1.Checked) { SQL += "WHERE field1='123' "; }
if (checkBox2.Checked) { SQL += "AND field2='456' "; }
if (checkBox3.Checked) { SQL += "AND field3='789' "; }
if (checkBox4.Checked) { SQL += "AND field4='abc' "; }
if (checkBox5.Checked) { SQL += "AND field5='def'"; }
Aber egal wie sehr ich drüber nachdenke, eine saubere Lösung will mir nicht einfallen wie ich das WHERE und vor allem die ANDs dynamisch einbeziehen kann.
Hat jemand eine Idee für mich?
Please also mark the comments that contributed to the solution of the article
Content-Key: 234314
Url: https://administrator.de/contentid/234314
Printed on: April 24, 2024 at 18:04 o'clock
6 Comments
Latest comment
Hallo!
Wenn LianenSchwingers Idee funktioniert, dann könnte man ja für jede CheckBox einen Platzhalter verwenden und diesen in den IF-Abfragen einfach per Replace im SQL-String ersetzen:
Grüße
Der Ratsuchende
Wenn LianenSchwingers Idee funktioniert, dann könnte man ja für jede CheckBox einen Platzhalter verwenden und diesen in den IF-Abfragen einfach per Replace im SQL-String ersetzen:
SQL = "SELECT * FROM database WHERE 1=1 And 2=2 And 3=3 And 4=4 And 5=5" |
Grüße
Der Ratsuchende
Hallo Ratsuchender,
braucht man doch gar nicht ein 1 = 1 reicht doch am Ende. So wie ich das in meinem 1. Post geschrieben habe.
G Jörg
braucht man doch gar nicht ein 1 = 1 reicht doch am Ende. So wie ich das in meinem 1. Post geschrieben habe.
string SQL = "SELECT * FROM database WHERE ";
if (checkBox1.Checked) { SQL += "field2='456' AND"; }
...
if (checkBox5.Checked) { SQL += "field2='def' AND"; }
SQL += "1 = 1";
G Jörg
Hallo Jörg!
Jepp, so geht's natürlich auch
Grüße
Der Ratsuchende
Jepp, so geht's natürlich auch
Grüße
Der Ratsuchende