Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. International
  3. Polish
  4. sqllite w qt
Forum Updated to NodeBB v4.3 + New Features

sqllite w qt

Scheduled Pinned Locked Moved Unsolved Polish
3 Posts 2 Posters 877 Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • R Offline
    R Offline
    rasterus
    wrote on last edited by
    #1

    Czy jest jakiś sposób, żeby sprawdzić czy otwarty jest prawidłowy plik bazodanowy? Bo można otworzyć cokolwiek i zarówno db.open jak i db.isValit zwracają, że wszystko ok nawet jak się otworzy binarkę. Nawet query nie wywala błędu jak dałem zapytanie sql na obrazku png. Przy db.open radośnie tworzy pusty plik, który wg biblioteki jest prawidłowym plikiem bazy danych.

    if(db.open) zwraca true nawet jak otworzyłem jako bazę danych sqllite /dev/null.

    sierdzioS 1 Reply Last reply
    0
    • R rasterus

      Czy jest jakiś sposób, żeby sprawdzić czy otwarty jest prawidłowy plik bazodanowy? Bo można otworzyć cokolwiek i zarówno db.open jak i db.isValit zwracają, że wszystko ok nawet jak się otworzy binarkę. Nawet query nie wywala błędu jak dałem zapytanie sql na obrazku png. Przy db.open radośnie tworzy pusty plik, który wg biblioteki jest prawidłowym plikiem bazy danych.

      if(db.open) zwraca true nawet jak otworzyłem jako bazę danych sqllite /dev/null.

      sierdzioS Offline
      sierdzioS Offline
      sierdzio
      Moderators
      wrote on last edited by
      #2

      Wow, dobre :-) Nigdy nie próbowałem otworzyć innego pliku w QSqlLite.

      Trochę rad dają tu (ostatni komentarz): https://stackoverflow.com/questions/42619851/how-to-check-database-is-exist-or-not i tu (też ostatni): https://forum.qt.io/topic/97957/how-to-check-if-sqlite-database-is-valid/5

      (Z(:^

      R 1 Reply Last reply
      0
      • sierdzioS sierdzio

        Wow, dobre :-) Nigdy nie próbowałem otworzyć innego pliku w QSqlLite.

        Trochę rad dają tu (ostatni komentarz): https://stackoverflow.com/questions/42619851/how-to-check-database-is-exist-or-not i tu (też ostatni): https://forum.qt.io/topic/97957/how-to-check-if-sqlite-database-is-valid/5

        R Offline
        R Offline
        rasterus
        wrote on last edited by rasterus
        #3

        @sierdzio dowiedziałem się, że trzeba sprawdzić przez QMimeType plik wcześniej. Ogólnie tam są niezłe jaja. Jak otwierasz przez db.open nieistniejący plik to tworzy automatycznie nowy pusty plik długości 0 bajtów. Dopiero jak dasz jakieś query, to tworzy strukturę bazy w pliku. query.LastError().text() przy każdym błędzie wywala no query, bez informacji co się dzieje. I taka śmieszna rzecz, wszystkie przykłady korzystania z sqllite mają if(!db.open)... Tylko nikt chyba nie sprawdził czy to coś daje :)

        P.S. a ile się narzucałem mięsa, zanim zauważyłem, że tworzy puste pliki radośnie.

        1 Reply Last reply
        1

        • Login

        • Login or register to search.
        • First post
          Last post
        0
        • Categories
        • Recent
        • Tags
        • Popular
        • Users
        • Groups
        • Search
        • Get Qt Extensions
        • Unsolved