Форум программистов, компьютерный форум, киберфорум
Python: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/13: Рейтинг темы: голосов - 13, средняя оценка - 4.62
0 / 0 / 0
Регистрация: 27.02.2018
Сообщений: 4

PyQt - доступ к нескольким БД sqlite3

28.06.2018, 18:53. Показов 2857. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер. Пытаюсь подключить несколько баз данных sqlite3 к модулю. Для этого в каждой базе указываю параметр connectionName. Однако, с этим параметром подключение не создаётся, даже для одной БД.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
from PyQt5 import QtSql, QtWidgets as QW
import sys
 
app = QW.QApplication(sys.argv)
 
item_data = QtSql.QSqlDatabase.addDatabase('QSQLITE', connectionName="db")#указываем тип базы данных, QSQLITE для базы типа sqlite3
item_data.setDatabaseName('item_data')#имя базы или путь до неё
item_data.open()
 
query = QtSql.QSqlQuery()  # объект запроса
 
#запрос на создание таблицы. пока для каждой вкладки будет отдельная таблица. id | tag
if 'test_table' not in item_data.tables():
    query = QtSql.QSqlQuery()#объект запроса
    query.exec('create table test_table(id integer, tag text unique on conflict fail)')#выполнение запроса,
                                                               # при повторяющемся имени тега будем обрабатывать ошибку
    query.finish()
 
 
#запрос с получаемыми параметрами
query.prepare('insert into test_table values(null, :tag)')  # данный метод используется, если в запрос нужно передать параметры
tags = ['folk', 'mitol', 'trip', 'jazz', 'folk']
query.setForwardOnly(True)  # задаём перемещение от начала к концу, якобы для экономии ресурсов...
query.bindValue(':tag', tags)#метод  вставляет значение в следующее поле при каждом вызове
query.execBatch()#метод выполнения запроса, если в качестве параметра используется список
 
#пробуем поймать ошибку при появлении повторяющегося значения
print(query.lastError().text())#выведет текст ошибки при повторяющемся значении, т.к. в поле tag указано unique
if query.lastError().isValid():print('error')#работает
if query.lastError().type() == QtSql.QSqlError.TransactionError: print('error type')
print(query.lastError().type())# ошибка №1 - ошибка с соединением с базой
 
query.finish()
 
 
item_data.close()
PyCharm выдаёт QSqlQuery :: prepare : database not open
Почему так получается? Без параметр connectionName соединение есть, но только для одной БД...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.06.2018, 18:53
Ответы с готовыми решениями:

Работа PyQt с SQLite3
Не подскажите, есть ли в PyQt какой-нибудь инструмент чтобы создавать таблицы для sqlite, а то всё перерыл, есть обычные способы, но меня...

Ввод значений в sqlite3 c использованием PyQt
Только начинаю что-то делать в sqlite и PYQT Функция click_btn при нажатии должна по идее добавлять в базу новой строкой информацию...

Доступ к БД MySQL и SQLite3 из dll
Какими на сегодня средствами можно организовать доступ и к MySQL, и к SQLite из dll-ки? Раньше не приходилось именно из dll делать , а...

2
1741 / 913 / 480
Регистрация: 05.12.2013
Сообщений: 3,074
28.06.2018, 23:21
При создании соединения по умолчанию ему задается имя defaultConnection и QtSql.QSqlQuery() тоже по умолчанию создается для defaultConnection, если задается имя соединения, то нужно указывать для какого соединения QSqlQuery() будет работать

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
from PyQt5 import QtSql, QtWidgets as QW
import sys
 
app = QW.QApplication(sys.argv)
 
item_data = QtSql.QSqlDatabase.addDatabase('QSQLITE', 'con1')#указываем тип базы данных, QSQLITE для базы типа sqlite3
item_data.setDatabaseName('item_data')#имя базы или путь до неё
item_data.open()
 
item_data2 = QtSql.QSqlDatabase.addDatabase('QSQLITE', 'con2')#указываем тип базы данных, QSQLITE для базы типа sqlite3
item_data2.setDatabaseName('test_item')#имя базы или путь до неё
item_data2.open()
 
query = QtSql.QSqlQuery()  # объект запроса
 
# #запрос на создание таблицы. пока для каждой вкладки будет отдельная таблица. id | tag
if 'test_table' not in item_data.tables():
    query = QtSql.QSqlQuery()#объект запроса
    query.exec('create table test_table(id integer, tag text unique on conflict fail)')#выполнение запроса,
                                                               # при повторяющемся имени тега будем обрабатывать ошибку
    query.finish()
 
 
# #запрос на создание таблицы. пока для каждой вкладки будет отдельная таблица. id | tag
if 'test_table' not in item_data2.tables():
    query = QtSql.QSqlQuery()#объект запроса
    query.exec('create table test_table(id integer, tag text unique on conflict fail)')#выполнение запроса,
                                                               # при повторяющемся имени тега будем обрабатывать ошибку
    query.finish()
 
#запрос с получаемыми параметрами
query = QtSql.QSqlQuery(item_data)
query.prepare('insert into test_table values(null, :tag)')  # данный метод используется, если в запрос нужно передать параметры
tags = ['folk', 'mitol', 'trip', 'jazz', 'folk']
query.setForwardOnly(True)  # задаём перемещение от начала к концу, якобы для экономии ресурсов...
query.bindValue(':tag', tags)#метод  вставляет значение в следующее поле при каждом вызове
query.execBatch()#метод выполнения запроса, если в качестве параметра используется список
 
#пробуем поймать ошибку при появлении повторяющегося значения
print(query.lastError().text())#выведет текст ошибки при повторяющемся значении, т.к. в поле tag указано unique
if query.lastError().isValid():print('error')#работает
if query.lastError().type() == QtSql.QSqlError.TransactionError: print('error type')
print(query.lastError().type())# ошибка №1 - ошибка с соединением с базой
 
query.finish()
 
query = QtSql.QSqlQuery(item_data2)
query.prepare('insert into test_table values(null, :tag)')  # данный метод используется, если в запрос нужно передать параметры
tags = ['folk', 'mitol', 'trip', 'jazz', 'folk']
query.setForwardOnly(True)  # задаём перемещение от начала к концу, якобы для экономии ресурсов...
query.bindValue(':tag', tags)#метод  вставляет значение в следующее поле при каждом вызове
query.execBatch()#метод выполнения запроса, если в качестве параметра используется список
 
#пробуем поймать ошибку при появлении повторяющегося значения
print(query.lastError().text())#выведет текст ошибки при повторяющемся значении, т.к. в поле tag указано unique
if query.lastError().isValid():print('error')#работает
if query.lastError().type() == QtSql.QSqlError.TransactionError: print('error type')
print(query.lastError().type())# ошибка №1 - ошибка с соединением с базой
 
query.finish()
 
 
item_data.close()
item_data2.close()
1
0 / 0 / 0
Регистрация: 27.02.2018
Сообщений: 4
29.06.2018, 07:16  [ТС]
Огромное спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.06.2018, 07:16
Помогаю со студенческими работами здесь

Доступ к нескольким БД
Добрый день. Появилась следующая задача, имеется бд общая к ней подключаюсь стандартными средствами EF Core. Но помимо нее необходимо...

Доступ к нескольким контроллерам
Доброго времени суток! Я новичок, не ругайтесь. Пока пополняюсь опытом для будущих проектов. Есть необходимость программировать...

Доступ к нескольким серверам
Разрабатываю ПО для создания пользовательского интерфейса по схеме данных БД. По поддерживаются VFP, MS SQL, PostgreSQL и клоны Interbase....

Доступ к нескольким Label'ам из других потоков
столкнулся с похожей проблемой (https://www.cyberforum.ru/csharp-net/thread428210.html)... надо дать доступ к нескольким Label ... тут...

Общий доступ к файлу нескольким процессам
Подскажите как передать от процесса родителя процессу потомку доступ к текстовому файлу?


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru