T
TempestSong10 сентября 2017 г. 6:16

QSqlTableModel UNIQUE constraint

QSqlTableModel, UNIQUE

Здравствуйте!

Есть файл базы данных встраиваемой SQLite3. В нем несколько таблиц, которые отображаются в QSqlTableModel модели. Заказчику оказалось неудобно редактировать и добавлять записи прямо в QTableView, поэтому пришлось писать под каждую модельку отдельный модальный диалог добавления/редактирования данных и потом уже данные из этого диалога отправлять в модельку.
И тут обнаружилось, что insertRecord(), которым я пользуюсь для вставки данных в случае добавления записи (не редактирования!), не кидает код ошибки на самый верх в клиентский код (то есть, мой код), если при попытке добавления обнаруживаются дубликаты и происходит нарушение ограничения UNIQUE по столбцам. В итоге данные наполовину добавляются в модель, но не добавляются в файл базы по причине того, что db-движок-то нарушения UNIQUE проверяет чётко и не пропускает невалидные относительно ограничений записи. На скриншоте ниже можно увидеть кривую полу-добавленную запись с отсутствующим автоматически сгенерированным базой ID.
https://s20.postimg.org/4qy56hwz1/image.png - ссылка на скриншот
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

3
Evgenii Legotckoi
  • 11 сентября 2017 г. 15:19
  • Ответ был помечен как решение.

Добрый день!
insertRecord() должна возвращать в случае неудачи false, а жанные в таблицу не должны добавляться теоретически.
Вообще я вручную проверял наличие существующей записи, а уж потом делал добавление новой информации в таблицу.
Проверку делал через SELECT . Хотя это может быть и не совсем правильный подход.

    T
    • 11 сентября 2017 г. 21:14

    Спасибо, буду иметь в виду Ваш подход. Но, промучившись вечер, решил задачу, пардон, по-быдлокодерски - через QSqlQuery делал запросы INSERT OR IGNORE , UPDATE OR IGNORE напрямую в таблицу, а потом перезагружал модель через select() . Я получил то, что хотел - при попытке провести операцию, приводящую к нарушению ограничений, движок базы данных выполняет sql-запрос "вхолостую". Но огромный минус такого подхода - феерическая дыра в безопасности, связанная с SQL-инъекциями. Пока не придумал, как это исправить.

      Evgenii Legotckoi
      • 12 сентября 2017 г. 1:29

      Думаю, что Ваш костыль несколько правильнее моего будет ))

        Комментарии

        Только авторизованные пользователи могут публиковать комментарии.
        Пожалуйста, авторизуйтесь или зарегистрируйтесь
        AD

        C++ - Тест 004. Указатели, Массивы и Циклы

        • Результат:50баллов,
        • Очки рейтинга-4
        m
        • molni99
        • 26 октября 2024 г. 1:37

        C++ - Тест 004. Указатели, Массивы и Циклы

        • Результат:80баллов,
        • Очки рейтинга4
        m
        • molni99
        • 26 октября 2024 г. 1:29

        C++ - Тест 004. Указатели, Массивы и Циклы

        • Результат:20баллов,
        • Очки рейтинга-10
        Последние комментарии
        i
        innorwall13 ноября 2024 г. 23:03
        Как написать игру на Qt - Урок 3. Взаимодействие с другими объектами what is priligy tablets What happens during the LASIK surgery process
        i
        innorwall13 ноября 2024 г. 20:09
        Использование переменных объявленных в CMakeLists.txt внутри C++ файлов where can i buy priligy online safely Tom Platz How about things like we read about in the magazines like roid rage and does that really
        i
        innorwall11 ноября 2024 г. 22:12
        Django - Урок 055. Как написать функционал auto populate field Freckles because of several brand names retin a, atralin buy generic priligy
        i
        innorwall11 ноября 2024 г. 18:23
        QML - Урок 035. Использование перечислений в QML без C++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
        i
        innorwall11 ноября 2024 г. 15:50
        Qt/C++ - Урок 052. Кастомизация Qt Аудио плеера в стиле AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
        Сейчас обсуждают на форуме
        i
        innorwall14 ноября 2024 г. 0:39
        добавить qlineseries в функции Listen intently to what Jerry says about Conditional Acceptance because that s the bargaining chip in the song and dance you will have to engage in to protect yourself and your family from AMI S…
        i
        innorwall11 ноября 2024 г. 10:55
        Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
        9
        9Anonim25 октября 2024 г. 9:10
        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
        ИМ
        Игорь Максимов3 октября 2024 г. 4:05
        Реализация навигации по разделам Спасибо Евгений!

        Следите за нами в социальных сетях