![]() |
Datenbank: MS SQL Express • Version: 2008 • Zugriff über: ADO
MSSQL und String-Felder
Hallo allerseits,
ich habe ein seltsames Verhalten des MSSQL Server 2008 festgestellt. Wenn ich eine Abfrage auf eine Tabelle ausführe, so werden mir alle Felder vom Datentyp String (bzw. Char oder NChar) mit maximaler Feldlänge angezeigt. D.h. das Resultat eines Feldes vom Typ NChar(20) wird als String angezeigt, der durch Leerzeichen auf 20 Zeichen ergänzt wird. Wenn ich nun eine Abfrage auf ein solches Feld durchführe:
SQL-Code:
erhalte ich kein Ergebnis. Erst wenn ich 'MeinText' am Ende um Leerzeichen ergänze, so dass die maximale Feldlänge erreicht wird, erhalte ich ein Ergebnis.
'WHERE Feld like ' + quotedstr(MeinText) + ' '
Ist das normal so? |
Re: MSSQL und String-Felder
Versuch mal:
SQL-Code:
MFG
'WHERE Trim(Feld,'' '') like ' + quotedstr(MeinText) + ' '
bzw. 'WHERE Feld like %' + quotedstr(MeinText) + '% ' Steffen |
Re: MSSQL und String-Felder
Deine Variante würde mir zuviele Resultate ausgebe. Angenommen ich suche nach dem Eintrag mit dem String 'a'. So erhalte ich nach deiner Variante alle Ergebnisse wo 'a' im String enthalten ist.
Ich denke, ich muss es so machen:
SQL-Code:
T-SQL kennt nur LTRIM und RTRIM und nicht Trim.
WHERE RTRIM(Feld) like ' + quotedStr(MeinText) + ' '
|
Re: MSSQL und String-Felder
Wieso nimmst du denn keine
![]() Und zusätzlich solltest du deine Abfragen auf prepared Statements umbauen. |
Re: MSSQL und String-Felder
Mein Vorredner hatte fast recht:
'WHERE Feld like ' + quotedstr(MeinText + '%'); muss es heißen. Sucht alle Records die mit MeinText anfangen |
Re: MSSQL und String-Felder
Hallo,
soweit ich das mitbekommen habe, werden NChar mit Leerzeichen aufgefüllt, bis die passende Länge erreicht ist.
SQL-Code:
wird nicht gehen, da das Leerzeichen ja an MeinText gehangen werden muss und nicht an das SQL. Besser wäre da wohl:
'WHERE Trim(Feld,'' '') like ' + quotedstr(MeinText) + ' '
SQL-Code:
wobei Du hier eventuell sogar 20 - Länge von MeinText Leerzeichen anfügen müsstest.
'WHERE Trim(Feld,'' '') like ' + quotedstr(MeinText + ' ')
Bei
SQL-Code:
sollte dann aber
WHERE RTRIM(Feld) like ' + quotedStr(MeinText) + ' '
SQL-Code:
ausreichen.
WHERE RTRIM(Feld) = ' + quotedStr(MeinText)
|
Re: MSSQL und String-Felder
Zitat:
|
Re: MSSQL und String-Felder
Ich hoffe das da nicht allzuviele Records drin sind.
WHERE RTRIM(Feld) = ' + quotedStr(MeinText) wird ein Table-Scan. Langsamer geht kaum mehr. |
Re: MSSQL und String-Felder
@nahpets: TRIM entfernt führende und nachfolgende Zeichen. Welches Zeichen, das bestimmst du mit dem entspr. Parameter.
SQL-Code:
...bewirkt in dem Beispiel also nichts anderes als ein RTRIM(Feld).
'WHERE Trim(Feld,'' '') like ' + quotedstr(MeinText)
MFG Steffen |
Re: MSSQL und String-Felder
Hallo,
Zitat:
SQL-Code:
besser?
'WHERE Feld = ' + quotedStr(MeinText + ' ')
|
Re: MSSQL und String-Felder
Ich denke wenn, dann eher via Format, oder?
Also: 'WHERE Feld = ' + quotedStr(Format('%.20s',['MeinText'])) MFG Steffen |
Re: MSSQL und String-Felder
@nahpet
SQL-Code:
Das Leerzeichen am Ende hat eigentlich nichts mit quotedstr(MeinText) zu tun. Das kann ignoriert werden.
WHERE Feld like ' + quotedStr(MeinText) + ' '
@hazard999 Zitat:
@Bernhard Geyer Zitat:
|
Re: MSSQL und String-Felder
Zitat:
|
Re: MSSQL und String-Felder
Entscheidungshilfe char oder varchar:
Haben die Strings grundsätzlich die gleiche Länge? Hier einige Beispiele: * Länderkürzel FR=Frankreich, DE=Deutschland * Währung 3-stellig nach ISO 4217 * eine GUID hexadezimal codiert mit 32 Zeichen (verwendet man den nativen Datentyp bracht man nur 16 Bytes) * ISBN-10 oder ISBN-13 (aber nur, wenn sicher ist, dass immer nur eine ISBN Länge verwendet wird) => dann Char verwenden Hat das Stringfeld eine Länge von 1 ? => dann Char verwenden In allen anderen Fällen varchar verwenden. |
Re: MSSQL und String-Felder
Ergänzung zu shmia's Aufstellung:
Ein Grenzfall ist ein Feld PLZ. Wenn es sich nur um deutsche Postleitzahlen handelt, passt CHAR(5). Wenn auch internationale Postcodes vorkommen, ist CHAR(10) denkbar, aber VARCHAR(10) besser. BLZ immer CHAR(8), Konto wieder ein Grenzfall. Aber über kurz oder lang wird das sowieso durch IBAN ersetzt. Da dieses Feld immer zwischen 16 und 34 Stellen hat, dürfte VARCHAR besser sein als CHAR. Jürgen |
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:44 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz