derroddy
Goto Top

MSSQL - Gibt es etwas exakteres als LIKE

Habe Probleme bei Vergleichen mit %

Hallo,

ich habe folgendes Problem: Ich habe in einer Tabelle die Einheiten gespeichert, die im Programm verwendet werden sollen mit ID und einem String. Nun brauche ich die IDs der Einheit, wenn ich den String habe.

z.B.:

EINHEITEN

1 m
2 cm

Ich möchte etwas mit Metern irgendwo einfügen

INSERT INTO X Einzufügen.Name AS Name, EINHEITEN.ID WHERE Einzufügen.Einheit LIKE EINHEITEN.Name

Das Funktioniert prinzipiell problemlos, aber ich habe ein Problem mit der Einheit '%'. Da würde das obige Query dann

INSERT INTO X Einzufügen.Name AS Name, EINHEITEN.ID WHERE Einzufügen.Einheit LIKE '%'

Natürlich findet er da dann alle Einheiten weil alle Namen LIKE '%' erfüllen. Hat einer eine Idee, wie ich das umgehen kann? Gibt es z.B. einen Befehl den ich anstelle von LIKE zum Vergleich von zwei varchars verwenden kann?

Content-ID: 56116

Url: https://administrator.de/forum/mssql-gibt-es-etwas-exakteres-als-like-56116.html

Ausgedruckt am: 23.01.2025 um 17:01 Uhr

AndreasHoster
AndreasHoster 11.04.2007 um 13:11:17 Uhr
Goto Top
Selbstverständlich gibt es was exakteres: =
INSERT INTO X Einzufügen.Name AS Name, EINHEITEN.ID WHERE Einzufügen.Einheit = EINHEITEN.Name
Wenn man es mit Konstanten machen will:
Einzufügen.Einheit = 'm' (Einfache Anführungszeichen)

Und, auch wenn es im Normalfall geht, ich würde auf Umlaute in Tabellen und Spaltennamen verzichten, kann manchmal doch zu Problemen führen.
derroddy
derroddy 11.04.2007 um 13:15:54 Uhr
Goto Top
Danke für die schnelle Antwort. Aus irgendeinem Grund war ich mir ganz sicher, dass man varchars nicht mit = vergleichen darf in SQL. Hab ich mich geirrt. So funktioniert es jedenfalls.