MSSQL Server - Suche nach Bezeichnungen mit Unterstrich im Namen
Auf Grund der Herstellervorgaben einer eingesetzten Software haben wir eine Schreibweise mit Unterstrich wählen müssen. Dies ist bei der Suche nicht immer hilfreich. Dieses kleine Workaround hat mich vermutlich wieder 67 Haare gekostet aber es funktioniert.
Da der Unterstrich in MSSQL eigentlich ein Platzhalter für ein beliebiges Zeichen ist, ist es nur über einen kleinen Umweg möglich dies als Zeichen abzufragen:
declare searchVar nvarchar(255)
set searchVar = char(0x5F)+'beliebiger Text'+char(0x5F) -- char(0x5F) = Unterstrich
select * from sys.objects
where CHARINDEX(@searchVar, [name]) > 0;
Die Funktion CHARINDEX gibt die Position des Auftretens des gesuchten Patterns, in diesem Fall _beliebigerText_, zurück.
declare searchVar nvarchar(255)
set searchVar = char(0x5F)+'beliebiger Text'+char(0x5F) -- char(0x5F) = Unterstrich
select * from sys.objects
where CHARINDEX(@searchVar, [name]) > 0;
Die Funktion CHARINDEX gibt die Position des Auftretens des gesuchten Patterns, in diesem Fall _beliebigerText_, zurück.
5 Kommentare Diskussionsverlauf
- -ricardo- schreibt am 21.07.2009 um 13:49:09 Uhr
- Netzheimer schreibt am 22.07.2009 um 09:32:34 Uhr
- -ricardo- schreibt am 22.07.2009 um 09:46:53 Uhr
- Netzheimer schreibt am 22.07.2009 um 13:29:15 Uhr
- -ricardo- schreibt am 22.07.2009 um 09:46:53 Uhr
- Netzheimer schreibt am 22.07.2009 um 09:32:34 Uhr
- Biber schreibt am 23.07.2009 um 13:47:12 Uhr
Netzheimer am 22.07.2009 um 09:32 Uhr
Hallo.
dein Vorschlag heißt ausgesprochen:
LIKE 'beliebigeAnzahlZeichen-Genau1beliebigesZeichen-beliebigeAnzahlZeichen'
Das kann man kürzen auf LIKE '%' und damit habe ich alles, zwar auch die mit Unterstrich, jedoch auch alle anderen.
Der Unterstrich wird in deiner Version behandelt wie es vorgesehen ist, nämlich als Platzhalter für 1 Zeichen. Nach dem Unterstrich selbst kannst du so nicht suchen.
Gruß
Netzheimer
dein Vorschlag heißt ausgesprochen:
LIKE 'beliebigeAnzahlZeichen-Genau1beliebigesZeichen-beliebigeAnzahlZeichen'
Das kann man kürzen auf LIKE '%' und damit habe ich alles, zwar auch die mit Unterstrich, jedoch auch alle anderen.
Der Unterstrich wird in deiner Version behandelt wie es vorgesehen ist, nämlich als Platzhalter für 1 Zeichen. Nach dem Unterstrich selbst kannst du so nicht suchen.
Gruß
Netzheimer
Netzheimer am 22.07.2009 um 13:29 Uhr
MSSQL hat keine Escape-Sequenzen.
Wir bewegen uns im Bereich Visual-Studio und MSSQL - nicht in anderen Programmiersprachen.
Netzheimer
Wir bewegen uns im Bereich Visual-Studio und MSSQL - nicht in anderen Programmiersprachen.
Netzheimer
Biber am 23.07.2009 um 13:47 Uhr
Moin Netzheimer und -ricardo-,
wenn ich auch mal kurz kommentieren kann:
-ricardo
Dort führt ein ...WHERE feld LIKE "*_*" in der Tat zum "richtigen" Ergebnis.
Aber was versteht Access auch schon von SQL?
@Netzheimer
Bei MSSQL werden Wildcards des LIKE-Operators maskiert durch "[" und "]"
Dann werden Prozentzeichen und Unterstriche als Literale behandelt.
Also teste einfach ein
Grüße
Biber
wenn ich auch mal kurz kommentieren kann:
-ricardo
Nimm doch
LIKE "%_%"
Und das klappt sogar bei MSSQL's ungeliebtem Cousin M$-Access.LIKE "%_%"
Dort führt ein ...WHERE feld LIKE "*_*" in der Tat zum "richtigen" Ergebnis.
Aber was versteht Access auch schon von SQL?
@Netzheimer
MSSQL hat keine Escape-Sequenzen.
So schlecht rede nicht ich mal ich über die Redmonder...Bei MSSQL werden Wildcards des LIKE-Operators maskiert durch "[" und "]"
Dann werden Prozentzeichen und Unterstriche als Literale behandelt.
Also teste einfach ein
01.
select * from sys.objects 02.
where name like '%[_]%';Grüße
Biber







