T
TempestSongSept. 10, 2017, 6:16 a.m.
QSqlTableModel UNIQUE constraint
Здравствуйте!
Есть файл базы данных встраиваемой SQLite3. В нем несколько таблиц, которые отображаются в QSqlTableModel модели. Заказчику оказалось неудобно редактировать и добавлять записи прямо в QTableView, поэтому пришлось писать под каждую модельку отдельный модальный диалог добавления/редактирования данных и потом уже данные из этого диалога отправлять в модельку.
И тут обнаружилось, что insertRecord(), которым я пользуюсь для вставки данных в случае добавления записи (не редактирования!), не кидает код ошибки на самый верх в клиентский код (то есть, мой код), если при попытке добавления обнаруживаются дубликаты и происходит нарушение ограничения UNIQUE по столбцам. В итоге данные наполовину добавляются в модель, но не добавляются в файл базы по причине того, что db-движок-то нарушения UNIQUE проверяет чётко и не пропускает невалидные относительно ограничений записи. На скриншоте ниже можно увидеть кривую полу-добавленную запись с отсутствующим автоматически сгенерированным базой ID.
https://s20.postimg.org/4qy56hwz1/image.png
- ссылка на скриншот
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.Do you like it? Share on social networks!
AD
- Akiv Doros
- Nov. 11, 2024, 10:58 p.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:50points,
- Rating points-4
m
- molni99
- Oct. 26, 2024, 8:37 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:80points,
- Rating points4
m
- molni99
- Oct. 26, 2024, 8:29 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:20points,
- Rating points-10
Last comments
Evgenii LegotckoiOct. 31, 2024, 9:37 p.m.
Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь МаксимовOct. 5, 2024, 2:51 p.m.
QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Now discuss on the forum
Evgenii LegotckoiJune 24, 2024, 10:11 p.m.
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey1Nov. 15, 2024, 2:04 p.m.
NSProjectJune 4, 2022, 10:49 a.m.
IscanderCheOct. 31, 2024, 10:43 p.m.
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Добрый день!
insertRecord() должна возвращать в случае неудачи false, а жанные в таблицу не должны добавляться теоретически.
Вообще я вручную проверял наличие существующей записи, а уж потом делал добавление новой информации в таблицу.
Проверку делал через SELECT . Хотя это может быть и не совсем правильный подход.
Спасибо, буду иметь в виду Ваш подход. Но, промучившись вечер, решил задачу, пардон, по-быдлокодерски - через QSqlQuery делал запросы INSERT OR IGNORE , UPDATE OR IGNORE напрямую в таблицу, а потом перезагружал модель через select() . Я получил то, что хотел - при попытке провести операцию, приводящую к нарушению ограничений, движок базы данных выполняет sql-запрос "вхолостую". Но огромный минус такого подхода - феерическая дыра в безопасности, связанная с SQL-инъекциями. Пока не придумал, как это исправить.
Думаю, что Ваш костыль несколько правильнее моего будет ))