To jest oczekiwany wynik:w SQL Server =
operator ignoruje końcowe spacje podczas porównywania.
SQL Server jest zgodny ze specyfikacją ANSI/ISO SQL-92 (sekcja 8.2, , Ogólne zasady #3) dotyczącą porównywania ciągów znaków ze spacjami. Standard ANSI wymaga wypełnienia ciągów znaków używanych w porównaniach, aby ich długości były zgodne przed porównaniem. Dopełnienie bezpośrednio wpływa na semantykę predykatów klauzuli WHERE i HAVING oraz inne porównania ciągów Transact-SQL. Na przykład Transact-SQL uważa ciągi 'abc' i 'abc' za równoważne dla większości operacji porównania.
Jedynym wyjątkiem od tej reguły jest predykat LIKE. Gdy prawa strona wyrażenia predykatu LIKE zawiera wartość ze spacją na końcu, SQL Server nie wypełnia tych dwóch wartości o tej samej długości przed wykonaniem porównania. Ponieważ celem predykatu LIKE z definicji jest ułatwienie wyszukiwania wzorców, a nie prostych testów równości ciągów, nie narusza to wspomnianej wcześniej sekcji specyfikacji ANSI SQL-92.
Źródło