Служебные символы в SQL запросе

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
AndreyG_80
Продвинутый пользователь
Продвинутый пользователь
 
Сообщения: 169
Зарегистрирован: 10.03.2006 (Пт) 13:27

Служебные символы в SQL запросе

Сообщение AndreyG_80 » 02.08.2006 (Ср) 22:20

Всем доброго времени суток.

В поиске не нашел подходящей темы.
Пожалуста подскажите или пошлите на похожую тему.
Открываю рекордсет, где источником являеться простой запрос
Код: Выделить всё
"SELECT * FROM Words WHERE Word LIKE '%" & txtWord.Text & "%'"

Но в базе есть слова с апострофом - '. Если такое слово вводиться в ТекстБоксе - то выскакивает ошибка.

Как сделать так, чтоб запрос работал коректно при любых символах в ТекстБоксе?

Большое спасибо за помощь

GSerg
Шаман
Шаман
 
Сообщения: 14286
Зарегистрирован: 14.12.2002 (Сб) 5:25
Откуда: Магадан

Сообщение GSerg » 02.08.2006 (Ср) 22:24

Как только вы переберёте все варианты решения и не найдёте нужного, тут же обнаружится решение, простое и очевидное для всех, кроме вас

AndreyG_80
Продвинутый пользователь
Продвинутый пользователь
 
Сообщения: 169
Зарегистрирован: 10.03.2006 (Пт) 13:27

Сообщение AndreyG_80 » 02.08.2006 (Ср) 22:50

Спасибо большое
Получаеться, что в ADO эта проблема решанться простым удваиванием апострофа?
Код: Выделить всё
"SELECT * FROM Words WHERE Word LIKE '%" & Replace(txtWord.Text, "'", "''") & "%'"

Если я так напишу оно будет работать 100%, здесь нет ни каких подводных камней?

Gmp
Обычный пользователь
Обычный пользователь
Аватара пользователя
 
Сообщения: 68
Зарегистрирован: 22.07.2006 (Сб) 17:04
Откуда: Германия

Сообщение Gmp » 02.08.2006 (Ср) 22:55

AndreyG_80
У меня так работает нормально.

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 03.08.2006 (Чт) 7:14

Будут. Потому что в MSSQL нужно экранировать только апостоф. Причем обрабатывать ситуацию, когда в апостофы заключена строка (т.е. вместо '''text''' нужно писать '#'text'#').
А в MySQL помимо апостофа нужно экранировать еще несколько символов.
А в каких-то других СУБД возможно нужно будет экранировать пробел.

Так что лучше сразу вводи в поисковик фразу "параметрические запросы" и читай, как надо делать правильно.
Lasciate ogni speranza, voi ch'entrate.


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 79

    TopList