Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.01.29;
Скачать: CL | DM;

Вниз

Экранирование кавычек в SQL   Найти похожие ветки 

 
АлександрМ   (2005-11-30 13:01) [0]

Используя компонент TQuery пытаюсь отправить SQL запрос вида:
UPDATE mytable SET field1="Текст. \" - это кавычка. Опять текст",  field2="Текст" WHERE field3=1111
Для экранирования кавычек использую обратный слеш, в соответствии с документацией по MySQL. Запрос выдаёт ошибку (без кавычки внутри текста запрос проходит). Если этот же запрос передаю в базу например через MySQL Front то всё работает.


 
Desdechado ©   (2005-11-30 13:09) [1]

а ты параметры не хочешь использовать, а?


 
АлександрМ   (2005-11-30 13:15) [2]

Если я буду использовать параметры, то TQuery сам разбедётся как кавычки экранировать? Сейчас попробую.


 
Плохиш ©   (2005-11-30 13:51) [3]

quotedstr


 
Anatoly Podgoretsky ©   (2005-11-30 13:56) [4]

АлександрМ   (30.11.05 13:15) [2]
Если будешь использовать параметры, то экранировать нечего.
Во вторых экранирование не имеет никакого отношения к TQuery


 
АлександрМ   (2005-11-30 14:31) [5]

Anatoly Podgoretsky, если экранирование не имеет никакого отношения к Query, то почему не работате мой запрос? Как будто ошибка в синтаксисе.

Я бы с радостью не использовал бы параметры. Мне гораздо удобнее составить сразу SQL запрос, чем вводить кучу параметров, а потом каждому присваивать значение.

В общем-то проблему сейчас решил. Спасибо всем за советы. Но непонимание осталось. Почему всё-таки не сработало экранирование обратным слешом?


 
Anatoly Podgoretsky ©   (2005-11-30 14:51) [6]

АлександрМ   (30.11.05 14:31) [5]
Работает он потому, что это информация для сервера, что следующий символ данного литерала не ограничитель, а символ.


 
АлександрМ   (2005-11-30 15:09) [7]

Anatoly Podgoretsky, запрос не работает! То есть, до сервера не доходит, что кавычка должна быть символом. Сервер почему-то считает, что это ограничитель! В результате чего и возникает проблема!


 
ANB ©   (2005-11-30 15:21) [8]


> АлександрМ   (30.11.05 15:09) [7]

Может я чего то путаю, но вы не пробовали обрамляющие кавычки заменить на одинарные ?


 
АлександрМ   (2005-11-30 18:16) [9]

ANB, тогда двойная кавычка проходит. ;-)
Только одинарные проходить перестают.


 
Плохиш ©   (2005-11-30 18:36) [10]


> АлександрМ   (30.11.05 18:16) [9]

Т.е. [3] совсем не помогает?


 
ANB ©   (2005-12-01 09:31) [11]


> АлександрМ   (30.11.05 18:16) [9]

А если у тебя в строках бывают разные кавычки - то не фиг парится, а переходи на параметры.
ЗЫ. В оракле \" и \" тоже не работает (другой синтаксис для этого). Обычно приходится использовать для маски в LIKE, например, когда нужно % искать.



Страницы: 1 вся ветка

Текущий архив: 2006.01.29;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.042 c
9-1116686883
!Trinix
2005-05-21 18:48
2006.01.29
Вопросы по моделям в игре


3-1132923178
tamroF
2005-11-25 15:52
2006.01.29
MS SQL сервер - это Microsoft SQL?


15-1136883578
Чапаев
2006-01-10 11:59
2006.01.29
SQL для MDB


15-1136629806
diwwww
2006-01-07 13:30
2006.01.29
Можно ли расчитать КПП?


15-1136356025
begin...end
2006-01-04 09:27
2006.01.29
С Днём рождения! 4 января