T
TempestSongҚыр. 10, 2017, 6:16 Т.Ж.
QSqlTableModel UNIQUE constraint
Здравствуйте!
Есть файл базы данных встраиваемой SQLite3. В нем несколько таблиц, которые отображаются в QSqlTableModel модели. Заказчику оказалось неудобно редактировать и добавлять записи прямо в QTableView, поэтому пришлось писать под каждую модельку отдельный модальный диалог добавления/редактирования данных и потом уже данные из этого диалога отправлять в модельку.
И тут обнаружилось, что insertRecord(), которым я пользуюсь для вставки данных в случае добавления записи (не редактирования!), не кидает код ошибки на самый верх в клиентский код (то есть, мой код), если при попытке добавления обнаруживаются дубликаты и происходит нарушение ограничения UNIQUE по столбцам. В итоге данные наполовину добавляются в модель, но не добавляются в файл базы по причине того, что db-движок-то нарушения UNIQUE проверяет чётко и не пропускает невалидные относительно ограничений записи. На скриншоте ниже можно увидеть кривую полу-добавленную запись с отсутствующим автоматически сгенерированным базой ID.
https://s20.postimg.org/4qy56hwz1/image.png
- ссылка на скриншот
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!
Пікірлер
Г
- Геній
- Қыр. 13, 2024, 12:46 Т.Қ.
C++ - Тест 001. Первая программа и типы данных
- Нәтиже:66ұпай,
- Бағалау ұпайлары-1
t
- torgaev_2024
- Қыр. 8, 2024, 6:20 Т.Ж.
C++ - Тест 001. Первая программа и типы данных
- Нәтиже:33ұпай,
- Бағалау ұпайлары-10
Соңғы пікірлер
Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
ВР
Linux жүйесінде файлдарды қалай көшіруге болады Screenshot_20240802-065123.png
Влад РусоковТам. 2, 2024, 1:47 Т.Ж.
QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
Енді форумда талқылаңыз
Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
BlinCTМаусым 25, 2024, 1 Т.Ж.
BlinCTМамыр 5, 2024, 5:46 Т.Ж.
Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
Добрый день!
insertRecord() должна возвращать в случае неудачи false, а жанные в таблицу не должны добавляться теоретически.
Вообще я вручную проверял наличие существующей записи, а уж потом делал добавление новой информации в таблицу.
Проверку делал через SELECT . Хотя это может быть и не совсем правильный подход.
Спасибо, буду иметь в виду Ваш подход. Но, промучившись вечер, решил задачу, пардон, по-быдлокодерски - через QSqlQuery делал запросы INSERT OR IGNORE , UPDATE OR IGNORE напрямую в таблицу, а потом перезагружал модель через select() . Я получил то, что хотел - при попытке провести операцию, приводящую к нарушению ограничений, движок базы данных выполняет sql-запрос "вхолостую". Но огромный минус такого подхода - феерическая дыра в безопасности, связанная с SQL-инъекциями. Пока не придумал, как это исправить.
Думаю, что Ваш костыль несколько правильнее моего будет ))