Саммерфилд Марк
Шрифт:
Для выполнения запросов с другим соединением мы передаем объект QSqlDatabase конструктору QSqlQuery:
Несколько соединений полезны, если мы хотим выполнять одновременно несколько транзакций, поскольку каждое соединение может использоваться только для одной активной транзакции. Когда мы используем несколько соединений с базой данных, мы можем все-таки иметь одно непоименованное соединение и QSqlQuery будет использовать это соединение, если не указано поименованное соединение.
Кроме QSqlQuery Qt содержит класс QSqlTableModel — интерфейс высокого уровня, позволяя нам не использовать выражения SQL «в чистом виде» для выполнения наиболее распространенных SQL—команд (SELECT, INSERT, UPDATE и DELETE). Этот класс может использоваться автономно без какого-либо графического пользовательского интерфейса или в качестве источника данных для QListView или QTableView.
Ниже приводится пример использования QSqlTableModel для выполнения команды SELECT:
Это эквивалентно запросу
Просмотр результирующего набора выполняется путем получения заданной записи функцией QSqlTableModel::record и доступа к отдельным полям с помощью функции value:
Функция QSqlRecord::value принимает либо имя поля, либо индекс поля. При работе с большими наборами данных рекомендуется задавать поля с помощью их индексов. Например:
Для вставки записи в таблицу базы данных мы действуем так же, как если бы делали вставку в двумерную модель: сначала вызываем функцию insertRow для создания новой пустой строки (записи) и затем используем setData для установки значения каждого столбца (поля записи).
После вызова submitAll запись может быть перемещена в другую позицию, зависящую от упорядоченности таблицы. Вызов submitAll возвратит false, если вставка окажется неудачной.
Важным отличием модели SQL от стандартной модели является необходимость вызова в модели SQL функции submitAll для записи всех изменений в базу данных
Для обновления записи мы должны сначала установить QSqlTableModel на запись, которую мы хотим модифицировать (например, используя функции select). Затем мы извлекаем запись, обновляем соответствующие поля и записываем наши изменения обратно в базу данных: