Форум программистов, компьютерный форум, киберфорум
C++ Qt
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
 Аватар для Lindemann66
4 / 4 / 5
Регистрация: 28.04.2010
Сообщений: 162

Экранирование - аналог addBindValue

14.10.2011, 13:44. Показов 1730. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!

Вопрос следующий

Работаю с БД (SQLite, Qt)

Хочу сделать универсальную функцию для выполнения операций insert
Примерный шаблон
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int DataBase::insert(QString tablename, QString columnnames, QString values) {
    //нужно как-то экранировать строку со значениями - values
 
    QSqlQuery query;
    query.prepare(QString("INSERT INTO %1 (%2) VALUES (%3)").arg(tablename).arg(columnnames).arg(values);
 
    //раньше экранирование делалось функцией addBindValue
    //query.addBindValue(value);
 
    query.exec();
 
    return query.lastInsertId().toInt();
}
Раньше, как следует из примера, экранирование осуществлялось за счёт функции addBindValue

Теперь, поскольку идёт подстановка за счёт arg, экранирование так сделать не получится

Вопрос - какие ещё есть функции аналоги addBindValue под мой случай?

Буду благодарен любому ответу!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.10.2011, 13:44
Ответы с готовыми решениями:

addBindValue
почему при запуске query.prepare("SELECT "+opt->CutList+" FROM moon WHERE name = ?"); ...

PyQt5, MySQL. Не работает addBindValue()
Не работает: query = QSqlQuery(db) query.prepare("SELECT AccessLevel FROM users WHERE Name='?'") ...

Утечка памяти QByteArray addBindValue
Доброго времени суток. Не могу победить утечку памяти. Выделяю буфер buf с помощью new (buf статический массив указателей) Заполняю...

1
 Аватар для oxotnik
1665 / 1134 / 80
Регистрация: 21.08.2008
Сообщений: 4,734
Записей в блоге: 1
14.10.2011, 13:54
передавай в качестве values парный массив типа:
QPair<QString, QVariant>values;
потом в цикле (по массиву) из первого значения пары собираешь строку вида : "aram1, aram2, ..., paramN"
ее вставляешь в текст запроса, и затем циклом (опять по массиву) биндишь в запрос значения параметров
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.10.2011, 13:54
Помогаю со студенческими работами здесь

QString экранирование
Если в QChar записать '\\' все отлично работает и этот символ выводится как '\' но если его добавить в QString, то на выводе он так и...

QRegExp экранирование последовательности
Возникла следующая проблема с экранированием. QRegExp rx(&quot;\\Q+-*/\\E&quot;); QString str = &quot;+-*/&quot;; str =...

Выполение команд в QProcess, экранирование?
Здравствуйте. Вот такая команда отправляется строкой в первый параметр QProcess::start(program) sed '/196162947/d' -i...

QSqlQuery и экранирование в запросах SELECT
Изучая работу с БД ( QSqlQuery ) наткнулся на, казалось бы, простую проблему: экранирование символов в переменных. В интернете полно...

Экранирование \\
Привет, есть код на кнопке открытие диалога. После открытия, путь записывается в таком виде &quot;С:\123\123\233.exe&quot; а мне нужно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru