Как я могу включить строки, содержащие специальные символы, в мое предложение WHERE?

Я использую SQL Server 2014 и столкнулся со следующей проблемой в предложении WHERE моего запроса T-SQL.

В моем предложении WHERE будут перечислены названия городов. Однако некоторые имена содержат такие символы, как апостроф. Пример: СЕН-ЖУЛЬЕН Д'ОТМАН

Мой T-SQL выглядит следующим образом:

SELECT
...

FROM [TownList]

WHERE [townName] IN

(
...,

...,

'ST JULIEN D'HOTMAN',

...,

)

Вышеприведенное не работает, потому что один или несколько из [townName] содержат апостроф.

Из решения, данного здесь (Как вставить значение, содержащее апостроф (одинарную кавычку)?, мне нужно переписать это значение как «ST JULIEN D''HOTMAN'

Это нормально, если у вас есть несколько имен, которые следуют этому принципу. Вы можете вручную исправить способ записи значений. Тем не менее, более 200-300 имен в моем списке имеют эти проблемы.

Есть ли альтернативное решение этой проблемы?

Почему не мочь вы экранируете символы? Это является решение.

Larnu 10.04.2022 12:38
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
0
1
33
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я бы использовал таблицу или временную таблицу для переноса ваших данных перед фильтрацией данных.

если вы не хотите изменять каждый [townName], вы можете попробовать SET QUOTED_IDENTIFIER OFF, а затем использовать двойные кавычки для строки «Идентифицировать».

Causes SQL Server to follow the ISO rules regarding quotation mark delimiting identifiers and literal strings. Identifiers delimited by double quotation marks can be either Transact-SQL reserved keywords or can contain characters not generally allowed by the Transact-SQL syntax rules for identifiers.

SET QUOTED_IDENTIFIER OFF;

SELECT
...

FROM [TownList]

WHERE [townName] IN

(
...,

...,

"ST JULIEN D'HOTMAN",

...,

)

SET QUOTED_IDENTIFIER ON;

Другие вопросы по теме