-
Столкнулся с неожиданным для меня явлением: Копирую запись запросом, где к полю Название спереди прибавляется "!Копия ", т.е. Insert Into ModelCatalog (..., Name) Select ... Concat("!Копия ", f.Name) from ...
В результате, к названию прибавляется пробел. Все символы между восклицательным знаком и пробелом игнорируются. Аналогичный результат имеют Concat_SW() и Insert() Если убрать воскл.знак, слово "копия" прибавляется. Вопрос, где прочитать про такое действие В.З. и как же все-таки его добавить?
-
escape?
-
универсальным было бы использование параметров. + попробуй кавычки на одинарные поменять - '!Копия ', возможна различная интерпретация (судя по скриптовым языкам, например питону, а что такое sql как не скрипт? ;)
-
Заменил ' Concat("!Копия ", f.Name) from ...' на ' Concat(' + QuotedStr('!') + ', "Копия ", F.Name) '
В отладчике кусок готового запроса получился: Concat('!', "Копия ", F.Name)
После выполнения, восклицательный знак проигнорирован. Решил выполнить тот же запрос через терминал. Запрос сработал как ожидалось первоначально. Т.е. проблема не в MySQL, а в используемом компоненте (AnyDAC)
Попробовал вставить двойной восклицательный знак Concat('!!', "Копия ", F.Name) Запрос сработал. Воющем, проблема решена.
Похоже, это не глюк, это фича энидака. Для экранирования в середине строки запроса одинокого слова комментария.
-
> одинокого слова комментария
ему было так одиноко и не уютно среди других, что он решил в середине экранироваться от остальных знаком восклицания, как бы крича нам: Я здесь! Я живой! :)
-
Только сейчас понял, это ж мне все запросы надо как-то переделывать. Если кто-то в примечаниях решит восклицательный знак поставить? В лучшем случае знак потеряется. Либо потеряется вместе с ним следующее слово, если пойдет без пробела.
-
> универсальным было бы использование параметров.
-
> универсальным было бы использование параметров.
У меня упомянутые запросы выполняются одной функцией ExecSQL(Connection, StrSQL) Для параметров придется или на каждый запрос свой компонент создавать или писать функцию через параметры. Пока ограничился автозаменой "!" на "!!" Там будет видно, теперь это не самое критичное.
|