Михаиллл
Михаиллл29. Juli 2019 04:41

Как в Qt записать базу в Android

Добрый день.
Как в Qt записать базу SQLite в Android?
Если просто копирую из ресурсов, то эту базу нельзя менять.
Если создаю через код, то не могу ее открыть (на виндовс работает).

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

9
Evgenii Legotckoi
  • 29. Juli 2019 04:43

Добрый день.

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

    Михаиллл
    • 29. Juli 2019 04:49

    Не помогает, беда в чем то другом.

      Evgenii Legotckoi
      • 29. Juli 2019 04:52

      Вы используете QStandardPaths для создания базы данных? Или просто по какому-то пути? Нужно через QStandardPaths выбирать местоположение базы данных для создания.

        Михаиллл
        • 29. Juli 2019 04:59

        Я делал так, создавал по определенному адресу (папка расположения + имя файла).
        А как использовать для этого QStandardPaths ?

        void AppCore::copyDbInFolder()
        {
            requestAndroidPermissions();
            dbAdress = getDirApp() + "/dataBase.db";
            //dbAdress.replace("/","\\");
            if( ! QFile::exists(dbAdress))
            {
                //QFile::copy(":/dataBase/dataBase.db", dbAdress); //:/icons/close.png
                QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");//not dbConnection
                db.setDatabaseName(dbAdress);
                db.open();
                QSqlQuery query;
                query.exec("CREATE TABLE downloadTable ("
                           "id       INTEGER PRIMARY KEY "
                                            "NOT NULL,"
                          " nameFile TEXT,"
                           "fileUrl  TEXT"
                       ");"
                );
                query.exec(" CREATE TABLE historyTable ("
                              " id       INTEGER PRIMARY KEY"
                                               " NOT NULL,"
                               "url      TEXT,"
                               "nameSite TEXT"
                           ");"
                );
                query.exec("CREATE TABLE openTabTable ("
                           "id       INTEGER NOT NULL"
                                           " PRIMARY KEY AUTOINCREMENT,"
                           "url      TEXT,"
                           "nameSite TEXT,"
                           "screen   TEXT"
                       ");"
                );
            }
            //QFile f1(dbAdress);
            //f1.setPermissions(QFileDevice::WriteUser);
        }
        
          Evgenii Legotckoi
          • 29. Juli 2019 05:01
          dbAdress  = QStandardPaths::standardLocations(QStandardPaths::DataLocation) + QDir::separator() + "dataBase.db"
          
            Михаиллл
            • 29. Juli 2019 05:22
            • (bearbeitet)

            Странно, если делаю так, то компилируется, правда этот файл тоже менять не могу

            dbAdress = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation).append("/myDataBaseForBrowser.db");
            

            А Ваш вариант не могу присвоить, т.к. тут QString и QChar

              Evgenii Legotckoi
              • 29. Juli 2019 05:31
              • (bearbeitet)

              Какого типа dbAdress? Это QString? Мой вариант с QDir::separator() явдяется классическим примером из документации Qt. Если dbAdress - это QString, то должно работать.

              Если только у вас там нет каких-то настроек, которые отключают автоматическиое преобразование строк. У Qt есть такое, но я сомневаюсь, что причина в этом.

              Также пробуйте исправить права доступа к файлу через QFile::setPermissions

                Михаиллл
                • 29. Juli 2019 06:02

                dbAdress это QString.
                С QFile::setPermissions тоже пробовал.
                Сейча попробовал один раз програмно удалить старую базу, после этого программа больше не может копировать базу, хотя строчки удаления я закаментировал, сделал qmake и удалил билды.
                Скажите пожалуйста, почему так и как это исправить?

                  Михаиллл
                  • 29. Juli 2019 08:20
                  • Die Antwort wurde als Lösung markiert.
                  void AppCore::copyDbInFolder()
                  {
                      requestAndroidPermissions();
                      //dbAdress = getDirApp() + "/dataBase.db";
                      dbAdress = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation).append("/myDataBaseForBrowser.db");
                      //dbAdress = QStandardPaths::standardLocations(QStandardPaths::DataLocation) + QDir::separator() + "dataBase.db"
                      //dbAdress =  QStandardPaths::standardLocations(QStandardPaths::AppDataLocation).append("/myDataBaseForBrowser.db");
                      //QFile f2(dbAdress);
                      //if (f2.remove()) {"remuve file";} else {"dont remove file";};
                      //dbAdress.replace("/","\\");
                      if( ! QFile::exists(dbAdress))
                      {
                          qDebug()<<"файл с базой не существует";
                          /*QFile::copy(":/dataBase/dataBase.db", dbAdress); //:/icons/close.png
                          QFile f1(dbAdress);
                          f1.setPermissions(QFileDevice::WriteUser);*/
                          QFile *db1 = new QFile(dbAdress);
                          if(db1->open(QFile::WriteOnly)){
                          QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");//not dbConnection
                          db.setDatabaseName(dbAdress);
                          db.open();
                          QSqlQuery query;
                          query.exec("CREATE TABLE downloadTable ("
                                     "id       INTEGER PRIMARY KEY "
                                                      "NOT NULL,"
                                    " nameFile TEXT,"
                                     "fileUrl  TEXT"
                                 ");"
                          );
                          query.exec(" CREATE TABLE historyTable ("
                                        " id       INTEGER PRIMARY KEY"
                                                         " NOT NULL,"
                                         "url      TEXT,"
                                         "nameSite TEXT"
                                     ");"
                          );
                          query.exec("CREATE TABLE openTabTable ("
                                     "id       INTEGER NOT NULL"
                                                     " PRIMARY KEY AUTOINCREMENT,"
                                     "url      TEXT,"
                                     "nameSite TEXT,"
                                     "screen   TEXT"
                                 ");"
                          );
                          db.commit();
                          db.close();
                  }
                      }
                      else {
                          qDebug()<<"файл с базой уже существует";
                      }
                      if(QFile::exists(dbAdress)){qDebug()<<"файл с базой записался";} else {qDebug()<<"файл с базой не записался";}
                      //QFile f1(dbAdress);
                      //f1.setPermissions(QFileDevice::WriteUser);
                  }
                  

                    Kommentare

                    Nur autorisierte Benutzer können Kommentare posten.
                    Bitte Anmelden oder Registrieren
                    Letzte Kommentare
                    A
                    ALO1ZE19. Oktober 2024 15:19
                    Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                    ИМ
                    Игорь Максимов5. Oktober 2024 14:51
                    Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                    d
                    dblas55. Juli 2024 18:02
                    QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                    k
                    kmssr9. Februar 2024 02:43
                    Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                    Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                    Jetzt im Forum diskutieren
                    J
                    JacobFib17. Oktober 2024 10:27
                    добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                    JW
                    Jhon Wick1. Oktober 2024 22:52
                    Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
                    КГ
                    Кирилл Гусарев27. September 2024 16:09
                    Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
                    F
                    Fynjy22. Juli 2024 11:15
                    при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                    Folgen Sie uns in sozialen Netzwerken