wp8fan
Goto Top

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?

Content-Key: 234314

Url: https://administrator.de/contentid/234314

Printed on: April 19, 2024 at 07:04 o'clock

Member: LianenSchwinger
LianenSchwinger Apr 02, 2014 updated at 14:39:05 (UTC)
Goto Top
Hallo,

nehm das WHERE mit in den SELECT-String und dann so etwas wie

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
Member: WP8Fan
WP8Fan Apr 02, 2014 at 14:42:23 (UTC)
Goto Top
Hallo Jörg,

Vielleicht hab ich vergessen zu erwähnen das die CheckBoxen 'optional' sind.

Wenn ich keine CheckBox auswähle würde mir der SQL-String aufgrund des WHERE um die Ohren fliegen.
=> ( "SELECT * FROM database WHERE" )

Ebenso würde mir das AND am Ende um die Ohren fliegen wenn nur eine CheckBox ausgewählt wäre.
=> if (checkBox5.Checked) { SQL += "field2='def' AND"; } wäre dann ja ( "SELECT * FROM database WHERE field2='def' AND" )
Member: LianenSchwinger
LianenSchwinger Apr 03, 2014 updated at 05:01:50 (UTC)
Goto Top
Hallo,

weder das WHERE nach das AND fliegen dir um die Ohren, da der SELECT immer mit einem 1 = 1 abgeschlossen wird.

SELECT * FROM database WHERE 1 = 1

SELECT * FROM database WHERE field2='def' AND 1 = 1  

G Jörg
Mitglied: 115420
115420 Apr 03, 2014 at 06:00:00 (UTC)
Goto Top
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:
SQL = "SELECT * FROM database WHERE 1=1 And 2=2 And 3=3 And 4=4 And 5=5"


Grüße

Der Ratsuchende
Member: LianenSchwinger
LianenSchwinger Apr 03, 2014 at 06:16:01 (UTC)
Goto Top
Hallo Ratsuchender,

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
Mitglied: 115420
115420 Apr 03, 2014 at 06:37:22 (UTC)
Goto Top
Hallo Jörg!

Jepp, so geht's natürlich auchface-wink


Grüße

Der Ratsuchende