Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

MSSQL Abfragen, wo Spalteninhalt in Vergleichsparameter enthalten sein soll...

Frage Entwicklung Datenbanken

Mitglied: Mondragor

Mondragor (Level 1) - Jetzt verbinden

25.02.2013 um 12:57 Uhr, 1922 Aufrufe, 7 Kommentare

Hallo,

ich habe ein Problem mit einer MSSQL-Abfrage, die ich machen will.
Es gibt beispielsweise 3 mögliche Vergleichsparameter, wie
- "weiße Schokolade"
- "braune Schokolade"
- "bittere Schokoladen"

und in einer Tabelle, die ich abfrage, steht nun z.B. in `Tabelle1$`.SPALTE1 in irgendeiner Zeile
" Schokolade".
Dieser Eintrag soll für alle 3 Parameter gefunden werden.
Prinzipiell bedeutet das, dass also der Spalteneintrag in dem Suchparameter quasi als Substring
enthalten sein muss.
Doch wie kann ich das formulieren?
Ich habe verschiedenes in MSQRY32 versucht, wie z.B.:

SELECT * FROM `c:\tabelle`.`Tabelle1$` Tabelle1
WHERE '%`Tabelle1`.SPALTE1%' LIKE "braune Schokolade"

oder

...
WHERE '%'+Tabelle1`.SPALTE1+'%' LIKE "braune Schokolade"

Leider ohne erfolg.
Frage: Wie kann man erfolgreich einen String mit Regexes zusammenbauen, am Beispiel dieser Where-Klausel
oder gibt es gar eine Funktion, die prüfen kann, ob ein Spalteneintrag als "Substring" in einem String enthalten ist?

Vielen Dank im Voraus für Eure Antworten.

Grüße,
Mondragor
Mitglied: LianenSchwinger
25.02.2013 um 13:12 Uhr
Hallo Mondragor,

das müsste mit folgendem RegEx klappen:

01.
(braune|weiße|bittere)? Schokolade(n)?
Getestet unter http://regexpal.com/ mit folgendem Suchtext.

01.
Das ist braune Schokolade 
02.
Das ist weiße Schokolade 
03.
Das sind bittere Schokoladen 
04.
Das ist nur Schokolade 
05.
Das ist gelbe Schokolade
G Jörg
Bitte warten ..
Mitglied: Mondragor
25.02.2013 um 13:22 Uhr
Hallo Jörg,

erstens weiß ich nicht, in welcher Weise ich das in die Abfrage einbauen soll?
Außerdem ist von Anfang an nicht unbedingt klar, welche Worte / Zeichenfolgen
vor / hinter "Schokolade" folgen. Die Parameter sind Variablen. braune, weiße und bittere waren nur
Beispiele, wie das aussehen könnte.
Gibts da nicht sowas wie beliebig lange / beliebige Zeichenketten?
Bitte warten ..
Mitglied: LianenSchwinger
25.02.2013 um 13:36 Uhr
Hallo,

zu 1) wie baue ich das ein:

01.
SELECT * 
02.
FROM 'c:\tabelle'.'Tabelle1$' Tabelle1  
03.
WHERE Tabelle1.SPALTE1 REGEXP '(braune|weiße|bittere)? Schokolade(n)?'
zu 2) was steht denn z.B. in Deinen Parameter(n)?

G Jörg
Bitte warten ..
Mitglied: Mondragor
25.02.2013 um 14:30 Uhr
Hallo nochmal Jörg,

zu 2.)
Es stehen verschiedene Sachen drin und es steht momentan nicht fest, was in Zukunft drin stehn wird.
Das kann von Tag zu Tag mehr werden und genau das ist ja das Problem. Der Spalteninhalt soll fest sein,
die Parameter aber nicht. Der Spalteninhalt " Schokolade" (hier nur ein Beispiel) soll immer gefunden werden,
wenn beliebige Zeichen quasi "% Schokoladen%" im Parameter steht. Wenn es also möglich.
Oft hat man ja den Fall, dass man sucht:

... WHERE `Tabelle1`.SPALTE1 LIKE '%Parameter%'

Hier ist es aber genau umgekehrt. Quasi
WHERE '%`Tabelle1`.Spalte1%' LIKE 'Parameter'
.
Das will ich nur eben auch funktionstüchtig haben, bei CONCAT oder '%'+ ... zeigt er aber kein ergebnis bzw. kennt CONCAT nicht und auch REGEXP erkennt er nicht. Das kann aber auch an msqry32 liegen, kann ich nicht mit Sicherheit sagen.
Bitte warten ..
Mitglied: LianenSchwinger
25.02.2013 um 14:40 Uhr
Hallo,

Ups, erstmal Entschuldigung hatte das MSSQL überlesen und gedacht, es geht um MySQL.

In MSSQL gibt es glaube ich gar keine regulären Ausdrücke.

G Jörg
Bitte warten ..
Mitglied: MadMax
26.02.2013 um 12:41 Uhr
Hallo Mondragor,

Zitat von Mondragor:
Hier ist es aber genau umgekehrt. Quasi
WHERE '%`Tabelle1`.Spalte1%' LIKE 'Parameter'

Wenn es genau umgekehrt ist, dann schreib es doch auch genau umgekehrt::
01.
where 'Parameter' like '%' + Tabelle1.Spalte1 + '%'
Gruß, Mad Max
Bitte warten ..
Mitglied: Mondragor
11.03.2013 um 11:08 Uhr
Wir haben das Problem nun anders gelöst. Danke trotzdem für Eure Antworten.
Mir war das zu unsicher, auf welche syntaktischen und semantischen Grundsätze die Software, die in sich nicht MS ist,
zurückgreift. Daher sind wir auf nummer sicher gegangen und haben die Gleichheit von Parameter und Tabellenwert in die
Abfrage geschrieben.
MSQRY32 hat nicht alles unterstützt, was wir gebraucht hätten. Ob die Drittanbietersoftware alle SQL-Befehle kennt, weiß
ich eben auch nicht. Drum lieber die Tabelle angleichen als die Gefahr einzugehen, dass es keine eindeutigen Ergebnisse gibt.
Bitte warten ..
Ähnliche Inhalte
C und C++
Über C++ Konsoleninhalt abfragen (4)

Frage von freaktastisch zum Thema C und C ...

Windows Server
gelöst MSSQL 2016 Express auf Windows Server 2008 R2 Standard? (2)

Frage von TiCar zum Thema Windows Server ...

Server
MSSQL Backup ohne Berechtigungen importieren (3)

Frage von ForgottenRealm zum Thema Server ...

Neue Wissensbeiträge
Batch & Shell

Batch - ein paar Basics die man kennen sollte

Tipp von Pedant zum Thema Batch & Shell ...

Microsoft

Restrictor: Profi-Schutz für jedes Window

Tipp von AlFalcone zum Thema Microsoft ...

Batch & Shell

Batch zum Zurücksetzen eines lokalen Profils

Tipp von Mr.Error zum Thema Batch & Shell ...

Heiß diskutierte Inhalte
Router & Routing
ASUS RT-N18U mit VPN Client hinter Fritzbox - Portforwarding (15)

Frage von marshall75000 zum Thema Router & Routing ...

Microsoft Office
Saubere HTML aus Word-Dokument (15)

Frage von peterpa zum Thema Microsoft Office ...

Hosting & Housing
gelöst Webserver bei WIX, aber DNS Server wo anders (9)

Frage von laster zum Thema Hosting & Housing ...