M
MadBear541Мамыр 15, 2017, 9:33 Т.Қ.

Проверка наличия записи в БД при выполнении запроса

Qt, SQL

Есть программа в которой происходит добавление данных в базу SQL. Необходимо реализовать функцию проверки наличия записи при нажатии кнопки "Сохранить", если запись есть должен выполняться запрос Update, в ином случае выполняется запрос Insert. Как это реализовать?

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

27
Evgenii Legotckoi
  • Мамыр 16, 2017, 12:35 Т.Ж.

Можно через QSqlQuery и логический оператор EXISTS сделать.

QSqlQuery query;
// Проверка наличия записей по дате
QString str = QString("SELECT EXISTS (SELECT * FROM TableExample WHERE Date = '%1');").arg("2017-08-03");
query.prepare(str);
query.exec();
query.next();

/* Если запись существует, то вызывается
 * информационное сообщение
 * */
if(query.value(0) != 0){
    QMessageBox::information(this, trUtf8("Error"), trUtf8("Record is exists"));
}
else
{
    // ToDo something
}

Также есть статья с проверкой наличия записей в базе данных

    M
    • Мамыр 16, 2017, 6:02 Т.Ж.

    Вопрос: есть способ обновить модель QSqlQeuryModel?

      Evgenii Legotckoi
      • Мамыр 16, 2017, 10:09 Т.Ж.

      Выполнить заново setQuery() с последней применённой QSqlQuery, с помощью метода query()

      model->setQuery(model->query());
        M
        • Мамыр 16, 2017, 9:14 Т.Қ.

        если использовать model->setQuery(model->query().lastQuery()); ? я так понял что в данном случае он вызывает последний запрос

          Evgenii Legotckoi
          • Мамыр 17, 2017, 12:04 Т.Ж.

          QSqlQuery всегда содержит только последний запрос, а lastQuery() возвращает этот запрос в виде строки QString, так что, если база данных используется одна, то разницы нет, в каком виде будет передаваться запрос в model->setQuery()

            M
            • Мамыр 17, 2017, 5:29 Т.Ж.

            столкнулся с проблемой. приходиться на кнопку дважды нажимать чтоб выполнялся запуск кода приведенного вами. вызов произвожу через connect к данному слоту

              Evgenii Legotckoi
              • Мамыр 17, 2017, 5:56 Т.Ж.

              Проблема в том, как вы применили код, который я вам привёл, а не в самом коде.

                M
                • Мамыр 17, 2017, 5:59 Т.Ж.

                проблема как я выяснил в том что connect соединение с слотом с первого нажатия не производит. а подключается к слоту только со второго нажатия и запускает нормально слот. connect(ui->pushButton, SIGNAL(clicked()), this, SLOT(tww())); вот так соединяю нажатие и слот

                  Evgenii Legotckoi
                  • Мамыр 17, 2017, 6:04 Т.Ж.

                  Вы запихали connect не в то место в коде. Написали некачественный алгоритм, по которому коннект создаётся не в нужное время.

                    M
                    • Мамыр 18, 2017, 7:55 Т.Ж.

                    Еще вопрос, с которым не могу разобраться. Есть ComboBox - raspsel, который позволяет выбрать поле из таблицы. Делаю я это следующим образом:

                     rasmd = new QSqlQueryModel(this);
                        QSqlQuery zrs;
                        zrs.exec("SELECT idr, CONCAT(rnumber, ' от ', rdata) FROM op");
                        rasmd->setQuery(zrs);
                        ui->raspsel->setModel(rasmd);
                        ui->raspsel->setModelColumn(1);
                    Теперь вопрос. Как сделать чтобы открыв форму для редактирования я видел выбранное значение и при этом мог поменять значение. через QDataWidgetMapper не получается правильно сделать. Не допонимаю как работает ComboBox
                      Evgenii Legotckoi
                      • Мамыр 18, 2017, 7:59 Т.Ж.

                      Начнём с того, что QSqlQueryModel является моделью только для чтения, она не может быть редактируемой. А также, ответьте на вопрос. Зачем Вы выполняете метод exec() у QSqlQuery? Когда потом помещаете этот QSqlQuery в модель QSqlQueryModel? Обращение к базе данных происходит дважды.

                        M
                        • Мамыр 18, 2017, 8:04 Т.Ж.

                        я так делаю потому что потом планирую сделать библиотеку sql запросов, потом исправлю, сейчас занимаюсь отладкой. Редактируемая же форма QSqlTableModel и QSqlRelationalTableModel. QSqlQueryModel я использую для извлечения данных из одной таблицы.

                          Evgenii Legotckoi
                          • Мамыр 18, 2017, 8:13 Т.Ж.

                          Ну тогда у QComboBox есть методы currentData(), currentText(), currentIndex() с помощью которых можно забрать текущее значение. Передать его в сторону формы редактирования и с помощью этого значения выбрать нужную строку из таблицы базы данных, чтобы отобразить её в форме для редактирования.

                            M
                            • Мамыр 21, 2017, 9:11 Т.Ж.

                            Опишу еще раз ситуацию. Есть таблица в которую посредством SQL запроса ложу данные, так как там необходимо в один столбец выводить несколько значений. Теперь встала проблема что при двойном клике по строке и вызове окна для редактирования программа ложится по сигналу полученному от операционки. я реализовал метод с использованием currentIndex()

                            edob = new editobject(ui->obv->selectionModel()->currentIndex().row());
                            edob экземляр формы для редактирования editobject, а obv таблица. при отладке выяснил что как только отрабатывает строка rmap->setCurrentModelIndex(rmod->index(row,0)); в форме редактирования, прилетает сигнал от операционной системы rmap = new QDataWidgetMappe как решить проблему. от QComboBox я на данном этапе отказался. у меня сама форма не отрабатывает
                              Evgenii Legotckoi
                              • Мамыр 21, 2017, 12:30 Т.Қ.

                              В смысле программа крашится и выдаёт Segmentation Fault?
                              Ну тогда обращаетесь видимо к объекту, который в данный момент не был инициализирован. Получается, что используете rmap раньше, чем этот объект был создан. Нужно перетряхнуть последовательность действий.

                                M
                                • Мамыр 22, 2017, 3:31 Т.Ж.

                                rmap инициализируется после его создания. не знаю что сделал, код не правил, но все заработало. только вот есть косяк о котором ранее не задумался. так как таблица в которой происходит вызов окна редактирования формируется по sql запросу, то индексы актуальны только для одного набора данных, для остальных заполнение происходит не верно. в связи с чем возникает вопрос если для использования QSqlQuery или QSqlQueryModel. Но в первую очередь у меня проблема с тем что сохранение изменений не происходит. Делаю как и всегда mapper->submit() и model->submitAll(). в других случаях все нормально

                                  Evgenii Legotckoi
                                  • Мамыр 23, 2017, 1:53 Т.Ж.

                                  Так вы используете model->submitAll() и при этом используете QSqlQueryModel в качестве этой model?

                                  Делаю как и всегда mapper->submit() и model->submitAll(). в других случаях все нормально

                                  Я фиксить баги по таким высказываниям не умею, а экстрасенсы в отпуске. Код показывать следует в таких случаях.

                                    M
                                    • Мамыр 23, 2017, 1:55 Т.Ж.

                                    нет. model = new QSqlTableModel

                                      M
                                      • Мамыр 23, 2017, 1:57 Т.Ж.

                                      QSqlQueryModel я использую для формирования визуальной таблицы из которой по двойному клику вызываю форму редактирования. в ней же использую стандартный подход QSqlTableModel и QDataWidgetMapper

                                        Evgenii Legotckoi
                                        • Мамыр 23, 2017, 2:36 Т.Ж.

                                        Тогда после применения настроек в форме редактирования, применяйте обновление данных в вашей QSqlQueryModel.

                                          M
                                          • Мамыр 23, 2017, 2:38 Т.Ж.

                                          я так и делаю. после редактирования у меня посылается сигнал по которому происходит обращение к слоту обновления. сначала думал не правильно реализовал. но посмотрев через консоль базы, выяснил что данные не обновились

                                            M
                                            • Мамыр 23, 2017, 3:47 Т.Ж.

                                            Никак не могу найти способ чтобы обойти проблему с индексами в форме приведенной на скриншоте. в этой форме отображается информация, о которой говорил ранее, ее я и редактирую. заполнение данной формы происходит при помощи QSqlQueryModel и по ряду показателей. проблема в том что если я меняю значение показателя (критерия отбора) то при выводе в таблицу индексы строк обновляются, т.е. они всегда идут с значения "1", что не соответствует индексу строки в sql таблице. Как результат форма редактирования заполняется не верно. Возможно из-за этого и не отрабатывает обновление данных

                                              Evgenii Legotckoi
                                              • Мамыр 23, 2017, 4:38 Т.Ж.

                                              Потому, что это не ID, а номера строк самой таблицы. Почитайте вот это сообщение , да и в принципе весь топик.

                                                M
                                                • Мамыр 23, 2017, 5:11 Т.Ж.

                                                вообще-то я делаю передачу индекса

                                                edob = new editobject(rrid, rayid, ui->obv->selectionModel()->currentIndex().row());
                                                где obv та самая таблица из которой я дергую информацию. а editobject форма для редактирования. в editobject индекс я использую в
                                                rmap->setCurrentModelIndex(rmod->index(row,0));
                                                rmap = new QDataWidgetMapper.

                                                  Evgenii Legotckoi
                                                  • Мамыр 23, 2017, 5:27 Т.Ж.

                                                  И дальше что? То, что вы привели мне две эти строчки ещё не говорит о том, что этот код работает правильно.

                                                  И вообще-то QModelIndex != ID в базе данных, index.row() != ID в базе данных

                                                  Он у Вас работает правильно? Вы получаете обновление данных в базе данных? - НЕТ . Иначе это обсуждение не длилось бы так долго.

                                                  А теперь, я увижу достаточно подробный код или нет? 

                                                    M
                                                    • Мамыр 23, 2017, 5:47 Т.Ж.

                                                    Код форм про которые говорил прикрепил. regrdit форма в которой отображается информация отбираемая из базы. editobject форма для редактирования

                                                      Evgenii Legotckoi
                                                      • Мамыр 28, 2017, 10:01 Т.Ж.

                                                      Как интересно. У вас используется выборка по условиям везде. Ничего удивительного, что когда создаёте editobject , то получаете не верные данные. Забирая номер строки из одной таблицы, пытаетесь с помощью него получить другие данные в другой таблице. В которой используются совершенно другие условия выборки. Как я и говорил, почитайте топик, что я Вам привёл выше. И забирайте данные не по номеру строки в модели, а по ID записи в базе данных.

                                                      P/S/ Код у Вас отвратительный. Если кто-то после вас будет работать с проектом, то ему проще будет написать программу заново.

                                                        Пікірлер

                                                        Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
                                                        Кіріңіз немесе Тіркеліңіз
                                                        OI
                                                        • Ora Iro
                                                        • Жел. 24, 2024, 2:38 Т.Қ.

                                                        C++ - Тест 001. Первая программа и типы данных

                                                        • Нәтиже:40ұпай,
                                                        • Бағалау ұпайлары-8
                                                        AD

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

                                                        • Нәтиже:50ұпай,
                                                        • Бағалау ұпайлары-4
                                                        m
                                                        • molni99
                                                        • Қаз. 26, 2024, 8:37 Т.Ж.

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

                                                        • Нәтиже:80ұпай,
                                                        • Бағалау ұпайлары4
                                                        Соңғы пікірлер
                                                        ИМ
                                                        Игорь МаксимовҚар. 22, 2024, 7:51 Т.Қ.
                                                        Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                                                        Evgenii Legotckoi
                                                        Evgenii LegotckoiҚаз. 31, 2024, 9:37 Т.Қ.
                                                        Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                                                        A
                                                        ALO1ZEҚаз. 19, 2024, 3:19 Т.Қ.
                                                        Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                                                        ИМ
                                                        Игорь МаксимовҚаз. 5, 2024, 2:51 Т.Қ.
                                                        Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                                                        d
                                                        dblas5Шілде 5, 2024, 6:02 Т.Қ.
                                                        QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                                                        Енді форумда талқылаңыз
                                                        Evgenii Legotckoi
                                                        Evgenii LegotckoiМаусым 24, 2024, 10:11 Т.Қ.
                                                        добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                                                        t
                                                        tonypeachey1Қар. 15, 2024, 2:04 Т.Қ.
                                                        google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                                                        NSProject
                                                        NSProjectМаусым 4, 2022, 10:49 Т.Ж.
                                                        Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                                                        9
                                                        9AnonimҚаз. 25, 2024, 4:10 Т.Қ.
                                                        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                                                        Бізді әлеуметтік желілерде бақылаңыз