![]() |
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 + ' ')
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:40 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