Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

C-Sharp - String-Manipulation (SQL String manuell generieren)

Frage Entwicklung C und C++

Mitglied: WP8Fan

WP8Fan (Level 1) - Jetzt verbinden

02.04.2014, aktualisiert 16:38 Uhr, 1313 Aufrufe, 6 Kommentare, 1 Danke

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?
Mitglied: LianenSchwinger
02.04.2014, aktualisiert um 16:39 Uhr
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
Bitte warten ..
Mitglied: WP8Fan
02.04.2014 um 16:42 Uhr
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" )
Bitte warten ..
Mitglied: LianenSchwinger
03.04.2014, aktualisiert um 07:01 Uhr
Hallo,

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

01.
SELECT * FROM database WHERE 1 = 1 
02.
 
03.
SELECT * FROM database WHERE field2='def' AND 1 = 1
G Jörg
Bitte warten ..
Mitglied: 115420
03.04.2014 um 08:00 Uhr
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
Bitte warten ..
Mitglied: LianenSchwinger
03.04.2014 um 08:16 Uhr
Hallo Ratsuchender,

braucht man doch gar nicht ein 1 = 1 reicht doch am Ende. So wie ich das in meinem 1. Post geschrieben habe.

01.
string SQL = "SELECT * FROM database WHERE "; 
02.
if (checkBox1.Checked) { SQL += "field2='456' AND"; } 
03.
... 
04.
if (checkBox5.Checked) { SQL += "field2='def' AND"; } 
05.
SQL += "1 = 1";
G Jörg
Bitte warten ..
Mitglied: 115420
03.04.2014 um 08:37 Uhr
Hallo Jörg!

Jepp, so geht's natürlich auch


Grüße

Der Ratsuchende
Bitte warten ..
Ähnliche Inhalte
C und C++
C sharp generieren jede 10 Sec wiederholen
gelöst Frage von chaos2goC und C++4 Kommentare

Ehm Theama eig C # aber ist nicht vorhanden deshalb in C und C Falls Falsch Bitte um Kopieren ...

C und C++
C Sharp SQL Abfrage Problem
Frage von 115122C und C++3 Kommentare

Hallo, ich möchte in C# eine Verbindung zu einer DB/Tabelle herstellen, eine Abfrage starten und die Ergebnismenge darstellen. Das ...

Batch & Shell
String herausfiltern
gelöst Frage von goodbytesBatch & Shell5 Kommentare

Hallo, ich möchte gerne bei vielen Maschinen per Loginscript den FQDN ermitteln. Dafür wollte ich ihn aus der Rückgabe ...

C und C++
Anzahl der Buchstaben in einem String Element Array C++
gelöst Frage von ProtectedC und C++3 Kommentare

Hallo, ich benötige Hilfe. Ich möchte gerne in den jeweiligen Elementen die Anzahl der Buchstaben zählen. Ich hatte an ...

Neue Wissensbeiträge
Mac OS X

MacOS wo ist die Tilde ?

Tipp von Alchimedes vor 4 StundenMac OS X1 Kommentar

Hallo, ich hab eine MacOS qwertz Keyboard auf US Layout umgestellt da die Sonderzeichen besser erreichbar sind. Leider fehlt ...

Datenschutz

Weitere Informationen zum Sicherheitsproblem BeA

Information von Penny.Cilin vor 11 StundenDatenschutz

Im folgenden ein weiterer Bericht über die Sicherheitsprobleme von Bea. Fataler Konstruktionsfehler im besonderen elektronischen Anwaltspostfach Gruss Penny

Windows 10

Systemdienste behalten nach Win10 inplace-Upgrade nicht die ggf. modifizierte Startart bei

Tipp von DerWoWusste vor 13 StundenWindows 103 Kommentare

Stellt Euch vor, Ihr habt ein Win10 System und modifiziert dort die Startart von Systemdiensten. Zum Beispiel wollt Ihr ...

Microsoft Office

Deaktivieren von Startbildschirm und Backstage-Ansicht in Office 2016 per Batch-Datei

Anleitung von SarekHL vor 16 StundenMicrosoft Office17 Kommentare

Guten Morgen zusammen! Ich habe mir gestern (auch mit Hilfe dieses Boards) ein Script gebastelt, um in Office 2016 ...

Heiß diskutierte Inhalte
Netzwerke
NTFS-Berechtigung
Frage von Daoudi1973Netzwerke23 Kommentare

Hallo zusammen und frohes neues Jahr (Sorry, ich bin spät dran) Meine Frage: 1- Ich habe einen Ordner im ...

Batch & Shell
AD-Abfrage in Batchdatei und Ergebnis als Variable verarbeiten
gelöst Frage von Winfried-HHBatch & Shell19 Kommentare

Hallo in die Runde! Ich habe eine Ergänzungsfrage zu einem alten Thread von mir. Ausgangslage ist die Batchdatei, die ...

Microsoft Office
Deaktivieren von Startbildschirm und Backstage-Ansicht in Office 2016 per Batch-Datei
Anleitung von SarekHLMicrosoft Office17 Kommentare

Guten Morgen zusammen! Ich habe mir gestern (auch mit Hilfe dieses Boards) ein Script gebastelt, um in Office 2016 ...

Windows 10
Netbook erkennt Soundkarte nicht - keinerlei Info zum Hersteller und Modell vom Netbook und Hardware bekannt
Frage von fyrb38Windows 1017 Kommentare

Guten Tag, meine Schwester reist in einigen Wochen für ein paar Monate ins Ausland und hat sich dafür ein ...